目录:

一、概述
二、os包
三、subprocess包
四、对比
五、参考文章


一、概述

python与shell交互的方式有一下几种:
os.system()os.popen()commands包subprocess包

二、os包

  1. os.system([cmd])
  1. 执行CMD,返回CMD的状态码(0 - 成功,其他 - 失败或被中断)
  2. 无管道
  1. os.popen([CMD], [mode = 'r' | 'w' ], buffersize)
  1. 开启子shell执行CMD,返回执行命令的输入流输出流文件对象。文件对象可读写,但只能进行读或写
  2. 底层通过os管道技术 实现
  3. 单向管道(只能读或写)
import os
#使用读通道
f = os.popen("ls -l")# 执行此语句后,将创建子shell运行参数中指定的命令,但是不阻塞父进程
f.read()# 执行读取操作时,将阻塞父进程
#使用写管道
#需要提前写好echo文件
'''
#echo.py
while True:
in = input()
if in == "quit" or in == "exit":
print("Bye")
break
print("[-] ", in)
'''
f = os.popen("python echo.py", "w")
f.write("hello")

二、subprocess包

  1. subprocess 模块通过os 底层的 管道技术 实现
  2. 模块提出的目标是替代:os.systemos.spawn*
函数
  1. call(*popenargs, timeout= None, **kwargs)
  1. 功能:调用子进程运行命令
  2. 返回值:0 或 非0值
  3. 阻塞父进程,直到该函数结束
  4. 结束条件:命令执行完成或超时
  5. 用于代替 os.system()
  6. 不支持管道
  1. check_call(*popenargs, **kwargs)
  1. 功能:检查在子进程中运行命令的执行情况
  2. 返回值:0。(命令退出码为0时,返回0;否则,无返回值,直接引发CalledProcessError异常)
  3. 阻塞父进程,直到该函数结束
  4. 结束条件: 命令执行完成超时
  5. 不支持管道
  1. check_output(*popenargs, timeout=None, **kwargs)
  1. 功能: 检查在子进程中运行命令
  2. 返回值: 程序的运行结果。(如果命令返回码为0,返回运行结果;否则,直接抛出CalledProcessError异常)
  3. 不阻塞父进程
  4. 不支持stdout的管道
  5. 指定参数:stderr = STDOUT 可捕获错误信息
  6. 支持参数:input
  1. getoutput(cmd)
  1. 功能: 获取子进程中执行命令的输出结果
  2. 返回值:执行命令的结果
  3. 不阻塞父进程
  4. 不支持管道
  5. 命令执行错误时,不引发异常
  1. getstatusoutput(cmd)
  1. 功能:获取子进程中执行命令的返回码和结果
  2. 返回值:(retcode, stdout)元组
  3. 不阻塞父进程
  4. 不支持管道
  5. 命令执行错误时,不引发异常
  1. run(args, *, stdin = None, input = None, stderr = None, shell = False, cwd = None, timeout = None, check = False, encoding = None, errors = None)
  1. 功能:开启子进程运行命令
  2. 不阻塞父进程
  3. 支持双向管道
  4. 参数check为True时,可能会引发异常
  5. run函数是对Popen类封装后形成的简单函数


https://blog.51cto.com/executer/2048295