在C程序中获取系统命令输出

时间:2013-06-14 11:23:50

标签: c unix io operating-system

有更好的方法吗?

int numOfCPU;
system("grep -c ^processor /proc/cpuinfo >> /tmp/cpuinfo");
FILE *fp = fopen("/tmp/cpuinfo", "r");
fscanf(fp, "%d", &numOfCPU);
fclose(fp);
system("rm /tmp/cpuinfo");

我不想创建中间文件然后将其删除。

编辑:

它不是从文件中读取。命令可以是“ls”或“echo'Hello world'”

3 个答案:

答案 0 :(得分:16)

好的,我在其他答案中感到困惑。无论如何,这个答案的哲学是一样的。您可以直接使用 popen 功能。

然后你有这样的事情:

int numOfCPU;
FILE *fp = popen("grep -c ^processor /proc/cpuinfo", "r");

fscanf(fp, "%d", &numOfCPU);
pclose(fp);

我希望它会有用。

答案 1 :(得分:4)

您需要使用重定向和管道来执行您要执行的操作。

popen 调用可以帮助你,但是如果你想要更灵活的东西,比如重定向输入,或者更安全,比如不在shell中运行字符串,你应该遵循这个例子,取自管道的手册页。

   #include <sys/wait.h>
   #include <stdio.h>
   #include <stdlib.h>
   #include <unistd.h>
   #include <string.h>

   int
   main(int argc, char *argv[])
   {
       int pipefd[2];
       pid_t cpid;
       char buf;

       if (argc != 2) {
        fprintf(stderr, "Usage: %s <string>\n", argv[0]);
        exit(EXIT_FAILURE);
       }
       if (pipe(pipefd) == -1) {
           perror("pipe");
           exit(EXIT_FAILURE);
       }

       cpid = fork();
       if (cpid == -1) {
           perror("fork");
           exit(EXIT_FAILURE);
       }

       if (cpid == 0) {    /* Child reads from pipe */
           close(pipefd[1]);          /* Close unused write end */

           while (read(pipefd[0], &buf, 1) > 0)
               write(STDOUT_FILENO, &buf, 1);

           write(STDOUT_FILENO, "\n", 1);
           close(pipefd[0]);
           _exit(EXIT_SUCCESS);

       } else {            /* Parent writes argv[1] to pipe */
           close(pipefd[0]);          /* Close unused read end */
           write(pipefd[1], argv[1], strlen(argv[1]));
           close(pipefd[1]);          /* Reader will see EOF */
           wait(NULL);                /* Wait for child */
           exit(EXIT_SUCCESS);
       }
    }

您应该修改子进程以使用dup2将标准输出重定向到管道,然后执行您希望它运行的命令。

答案 2 :(得分:-3)

使用awk

#include <stdlib.h>
#include <stdio.h>

void main()
{
    int numOfCPU =0;

    system ("awk '/processor/{numOfCPU++}END{print numOfCPU}' /proc/cpuinfo");
}