例如 mysql 命令,当你使用mysql登陆时,会要你输入用户名和密码,然后就可以执行sql语句,界面会返回sql的结果。
现在就想 在程序中集成这些操作,将这些输入输出放到程序中,问一下有什么好办法吗?
现在就想 在程序中集成这些操作,将这些输入输出放到程序中,问一下有什么好办法吗?
解决方案
20
C语言可通过popen执行shell命令,fgets获取输出,pclose关闭。
很多命令都是可以一步到位的,不用一步一步的交互(例如提示输入密码,然后用户再输入密码)。
例如mysql,执行查询命令 mysql -hlocalhost -uroot -pmypwd -e “select * from mydb.mytbl”
在C程序中调用popen(“mysql -hlocalhost -uroot -pmypwd -e “select * from mydb.mytbl” “, “r”),然后用fgets获取输出结果
很多命令都是可以一步到位的,不用一步一步的交互(例如提示输入密码,然后用户再输入密码)。
例如mysql,执行查询命令 mysql -hlocalhost -uroot -pmypwd -e “select * from mydb.mytbl”
在C程序中调用popen(“mysql -hlocalhost -uroot -pmypwd -e “select * from mydb.mytbl” “, “r”),然后用fgets获取输出结果
10
popen实际上建立了管道,一般执行shell命令都一步到位即可,没必要非要输入,若果你非要输入的话,也可以用fputs输入,然后再fgets获取结果。
10
仅供参考:
#include <stdio.h> #include <sys/types.h> #include <sys/wait.h> #include <unistd.h> pid_t rw_popen(char* cmd, FILE **rfile, FILE **wfile) { int pipefd[2],pipefd2[2]; //管道描述符 pid_t pid; //进程描述符 if (pipe(pipefd) < 0) //建立管道 { printf("rw_popen() pipe create error/n"); return 0; } if (pipe(pipefd2) < 0) //建立管道 { printf("rw_popen() pipe create error/n"); return 0; } pid = fork(); //建立子进程 if (pid < 0) return 0; if (0 == pid) //子进程中 { close(pipefd[0]); dup2(pipefd[1], 1); close(pipefd[1]); dup2(pipefd2[0], 0); close(pipefd2[0]); close(pipefd[1]); char *argv[] = { "/bin/sh", "-c", cmd, NULL }; if (execvp("/bin/sh", argv) < 0) //用exec族函数执行命令 exit(1); } close(pipefd[1]); *rfile = fdopen(pipefd[0], "r"); close(pipefd2[0]); *wfile = fdopen(pipefd2[1], "w"); return pid; } void rw_pclose(pid_t pid, FILE *rfile, FILE *wfile) { int status; waitpid(pid, &status, 0); fclose(rfile); fclose(wfile); } int main() { char buf1[1024]; FILE *file1, *file2; pid_t pid; pid = rw_popen("sh", &file1, &file2); if (pid) { fputs("pwd;exit;\n",file2); fflush(file2); if (fgets(buf1, 1400, file1)) { puts(buf1); } rw_pclose(pid, file1, file2); } return 1; }
10
mysql 或其他软件本身有相似直接在控制台运行的吧
如 mysql -Dxxx -e “xxx.sql” > 重定向文件 | grep “你想要的”
如 mysql -Dxxx -e “xxx.sql” > 重定向文件 | grep “你想要的”