popen() 的应用

#include<stdio.h>
FLIE * fp = popen(“ls -l”,“r”);失败为空,只要是指针的类型,返回值均为空,只要是判断的函数,失败为0,成功为1;
fread(buf , sizeof(char),sizeof(buf),fp); 把结果定向到 buf 里面
popen() 与exec 族函数不同的是,popen()还是要转回来 执行自己的函数

// add.c 
#include <stdio.h>

int main()

{
    int i , j; 
    scanf("%d%d",&i ,&j);

    printf("sum = %d\n",i+j);
    return 0;
}
//p.c
#include <stdio.h>

int main()
{
    int i, j;
    printf("Hello world\n");
    return 0;
}
// popen_w.c
#include <stdio.h>
#include<stdlib.h>
#include<unistd.h>
int main()
{
    FILE * fp = popen("./add", "w");
    if ( fp ==NULL )
    {
        printf("popen is wrong \n");
    }
    char buf[128]="3 4";
    fwrite(buf,sizeof(char),sizeof(buf),fp);  // 将buf 的内容餐位参数,写入 add.c的参数中
    pclose(fp);
    FILE *fp2 = popen("./p","r");
    fread(buf,sizeof(char),sizeof(buf),fp2);  //将输出到屏幕上的内容输出到buf里面
    printf("buf = %s",buf);
    printf("popen_w.c is over\n");
    pclose(fp2);
}
int main()
{
    FILE * fp = popen ( "ls -l","r"); // 将命令行的命令写入到 buf中
//  FILE * fp = popen("ls", "r");
    if ( fp ==NULL )
    {
        printf("popen is wrong \n");
    }
    char buf[128]={0};
    int ret= fread(buf,sizeof(char), sizeof(buf), fp);
    if( ret == -1 )
    {
        printf("fread is wrong \n");
    }
    printf("buf[127]=%c\n",buf[127]);
    printf("buf= %s\n",buf);
    
}
### Python `Popen` 使用方法及示例 #### 创建子进程并与其交互 为了创建一个新的进程并与之通信,可以使用 `subprocess.Popen` 类。此类提供了灵活性来管理子进程的标准输入、标准输出以及错误流。 ```python from subprocess import Popen, PIPE # 启动一个外部命令并将stdout和stderr重定向到PIPE proc = Popen(['echo', 'Hello World'], stdout=PIPE, stderr=PIPE) # 获取命令执行后的返回结果 output, error = proc.communicate() print(f'Output: {output.decode()}') if error: print(f'Error: {error.decode()}') ``` 上述代码展示了如何启动一个简单的命令,并通过管道读取其输出[^2]。 #### 设置参数传递给构造器 当实例化 `Popen` 对象时,可以通过向构造函数提供不同的参数来自定义行为: - **args**: 要运行的命令及其参数列表或者字符串形式。 - **bufsize**: 缓冲区大小;默认情况下为0(无缓冲),可设置为1表示行缓存或负数代表全缓冲。 - **executable**: 可选字段用于指定要执行的实际文件路径,在某些平台上可能有用。 - **stdin**, **stdout**, 和 **stderr**: 控制子进程中这些流的行为,默认值通常就足够用了。 - **preexec_fn/pre creation flags/startupinfo/close_fds**: 平台特定选项,允许更细粒度控制新进程属性。 更多细节可以在官方文档中找到关于各个平台的支持情况说明。 #### 实际应用场景举例 假设有一个场景是要调用 Git 来获取当前分支名称: ```python import subprocess def get_current_git_branch(): try: process = subprocess.Popen( ['git', 'rev-parse', '--abbrev-ref', 'HEAD'], stdout=subprocess.PIPE, universal_newlines=True ) output = process.stdout.read().strip() exit_code = process.wait(timeout=5) if exit_code != 0: raise Exception('Failed to retrieve git branch.') return output except FileNotFoundError as e: raise Exception('Git not installed or repository does not exist.') from e branch_name = get_current_git_branch() print(branch_name) ``` 这段脚本演示了怎样安全地处理潜在异常,并且合理利用超时机制防止无限等待子进程完成。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值