Linux中的popen()函数可以在程序中执行一个shell命令,并返回命令执行的结果。有两种操作模式,分别为读和写。在读模式中,程序中可以读取到命令的输出,其中有一个应用就是获取网络接口的参数。在写模式中,最常用的是创建一个新的文件或开启其他服务等。
#include <stdio.h>
函数原型:
FILE *popen(const char *command, const char *type);
函数说明:
popen()函数通过创建一个管道,调用fork()产生一个子进程,执行一个shell以运行命令来开启一个进程。这个管道必须由pclose()函数关闭,而不是fclose()函数。pclose()函数关闭标准I/O流,等待命令执行结束,然后返回shell的终止状态。如果shell不能被执行,则pclose()返回的终止状态与shell已执行exit一样。
type参数只能是读或者写中的一种,得到的返回值(标准I/O流)也具有和type相应的只读或只写类型。如果type是"r"则文件指针连接到command的标准输出;如果type是"w"则文件指针连接到command的标准输入。
command参数是一个指向以NULL结束的shell命令字符串的指针。这行命令将被传到bin/sh并使用-c标志,shell将执行这个命令。
popen()的返回值是个标准I/O流,必须由pclose来终止。前面提到这个流是单向的(只能用于读或写)。向这个流写内容相当于写入该命令的标准输入,命令的标准输出和调用popen()的进程相同;与之相反的,从流中读数据相当于读取命令的标准输出,命令的标准输入和调用popen()的进程相同。
如果调用fork()或pipe()失败,或者不能分配内存将返回NULL,否则返回标准I/O流。popen()没有为内存分配失败设置errno值。如果调用fork()或pipe()时出现错误,errno被设为相应的错误类型。如果type参数不合法,errno将返回EINVAL。
例子:
#include <stdlib.h>
#include <stdio.h>
#define BUF_SIZE 1024
char buf[BUF_SIZE];
int main(void)
FILE * p_file = NULL;
p_file = popen("ifconfig eth0", "r");
if (!p_file) {
fprintf(stderr, "Erro to popen");
while (fgets(buf, BUF_SIZE, p_file) != NULL) {
fprintf(stdout, "%s", buf);
pclose(p_file);
return 0;
输出结果:
root@ye:/home/ye# gcc -Wall test_popen.c -o test_popen
root@ye:/home/ye# ./test_popen
eth0 Link encap:Ethernet HWaddr 00:16:3e:5f:31:4c
inet addr:172.20.110.214 Bcast:172.20.110.255 Mask:255.255.255.0
inet6 addr: fe80::216:3eff:fe5f:314c/64 Scope:Link
inet6 addr: 2001:250:3c02:74a:216:3eff:fe5f:314c/64 Scope:Global
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
RX packets:683756 errors:0 dropped:2 overruns:0 frame:0
TX packets:8678 errors:0 dropped:0 overruns:0 carrier:0
collisions:0 txqueuelen:1000
RX bytes:161460288 (161.4 MB) TX bytes:554406 (554.4 KB)
就像百度百科中所说popen()函数通过创建一个管道,调用fork()产生一个子进程,执行一个shell以运行命令来开启一个进程。这个管道必须由pclose()函数关闭。
其中”必须由pclose()函数关闭“是一个容易被忽视的点,这不光光浪费资源的问题,更涉及到子进程的周期,从而影响函数结果。
比如我在程序中用popen()执行一个SQL脚本,向数据库中插入大量的数据(大约有一万多条
FILE * popen ( const char * command , const char * type );
int pclose ( FILE * stream );
函数说明
popen() 函数通过创建
常见的操作是创建一个管道连接到另一个进程,然后读其输出或向其输入端发送数据,为此,标准I/O库提供了两个函数popen和pclose。这两个函数实现的操作是:创建一个管道,调用fork产生一个子进程,关闭管道的不使用端,执行一个shell以运行命令,然后等待命令终止。
#include <stdio.h>
FILE *popen(const char *cmdstring,...
标准I/O函数库提供了popen函数,它启动另外一个进程去执行一个shell命令行。
这里我们称调用popen的进程为父进程,由popen启动的进程称为子进程。
popen函数还创建一个管道用于父子进程间通信。父进程要么从管道读信息,要么向管道写信息,至于是读还是写取决于父进程调用popen时传递的参数。下在给出popen、pclose的定义:
C语言使用
popen命令调用python并传参
环境:anaconda3+mariadb
最近写一个
C语言程序从串口读取数据,然后调用Python,将数据传给python存入数据库并打印出来的程序。用了很多种方法尝试调用python。最后发现最简单好用的还是
popen命令。
test.py 用于获取C程序传递的数据存入数据库并打印出来
#test.py
import sys
import pymysql
x = int(sys.argv[1])
conn=pymysql.connect(
最简单的两个程序之间传递数据的方法就是使用popen和pclose 函数,原型如下:
#include<stdio.h>
FILE *popen(const char *command,const char *open_mode);
in pclose(FILE *stream_to_close);
1、popen函数
popen可以允许一个程序将另一个程序作为新进程来启动,并可以传递...