subprocess库学习之run(函数)

subprocess库学习之run(函数)

一、简介

subprocess.run 是 Python 3.5 及以上版本中的一个函数,用于运行外部命令并等待其完成。该函数是 subprocess 模块中常用的工具之一,取代了早期的 os.system 等方法,提供了更强大的功能和更灵活的参数配置。

二、语法和参数

语法

python 复制代码
subprocess.run(args, *, stdin=None, input=None, stdout=None, stderr=None, capture_output=False, shell=False, cwd=None, timeout=None, check=False, encoding=None, errors=None, text=None, env=None, universal_newlines=None)

参数

  • args: 运行的命令及其参数,通常是一个列表或字符串。
  • stdin : 子进程的标准输入,可设置为 PIPE、文件对象或 None
  • input : 传递给子进程的输入数据,作为 stdin 的内容。
  • stdout : 子进程的标准输出,可设置为 PIPE、文件对象或 None
  • stderr : 子进程的标准错误输出,可设置为 PIPE、文件对象或 None
  • capture_output : 如果设置为 True,则同时捕获 stdoutstderr,等价于设置 stdout=PIPE, stderr=PIPE
  • shell : 如果设置为 True,则通过 shell 执行命令。
  • cwd: 设置子进程的当前工作目录。
  • timeout : 设置子进程的运行时间上限,超时会抛出 TimeoutExpired 异常。
  • check : 如果设置为 True,且子进程退出码非零,则抛出 CalledProcessError 异常。
  • encoding : 如果指定了 text=True,则使用此编码来解码子进程的输出。
  • errors : 处理解码错误的方式,例如 ignorereplace
  • text/universal_newlines : 如果设置为 True,则 stdinstdoutstderr 会以文本模式进行处理。
  • env: 用于设置子进程的环境变量。

返回值

  • CompletedProcess: 该对象包含了子进程的运行结果,例如 argsreturncodestdoutstderr 等。

三、实例

3.1 运行简单的 shell 命令
  • 代码

    • linux

      python 复制代码
      import subprocess
      
      result = subprocess.run(['echo', 'Hello, World!'], capture_output=True, text=True)
      print(result.stdout)
    • Windows

      python 复制代码
      import subprocess
      
      result = subprocess.run('echo Hello, World!', shell=True, capture_output=True, text=True)
      print(result.stdout)
  • 输出

python 复制代码
Hello, World!
3.2 捕获命令的错误输出
  • 代码
python 复制代码
import subprocess

result = subprocess.run(['ls', '/nonexistent'], capture_output=True, text=True)
print("Return code:", result.returncode)
print("Error output:", result.stderr)
  • 输出
python 复制代码
Return code: 2
Error output: ls: cannot access '/nonexistent': No such file or directory
3.3 使用 shell 运行命令
  • 代码
python 复制代码
import subprocess

result = subprocess.run('echo Hello from shell', shell=True, capture_output=True, text=True)
print(result.stdout)
  • 输出
python 复制代码
Hello from shell

四、注意事项

  1. 使用 shell=True 时要特别小心,可能会带来安全风险,特别是在处理不可信的输入时。

  2. timeout 参数可用于限制命令的执行时间,但在超时情况下,需要处理可能残留的子进程。

  3. 默认情况下,subprocess.run 会等待命令执行完毕,如果不需要等待,可以考虑使用 subprocess.Popen

  4. ⭐⭐⭐linux和windows下使用上面方法的不同

    linux下的许多命令(在linux是实际上可执行文件)在 Windows 系统上,是内部命令(built-in command),而非独立的可执行文件。

    因此,不能直接通过 subprocess.run 以这种方式运行。我们可以通过设置 shell=True 来解决此问题,因为在 shell 模式下,Windows 的内部命令将可正常执行。

相关推荐
傻啦嘿哟12 分钟前
如何使用 Python 开发一个简单的文本数据转换为 Excel 工具
开发语言·python·excel
B站计算机毕业设计超人18 分钟前
计算机毕业设计SparkStreaming+Kafka旅游推荐系统 旅游景点客流量预测 旅游可视化 旅游大数据 Hive数据仓库 机器学习 深度学习
大数据·数据仓库·hadoop·python·kafka·课程设计·数据可视化
风尚云网34 分钟前
风尚云网前端学习:一个简易前端新手友好的HTML5页面布局与样式设计
前端·css·学习·html·html5·风尚云网
IT古董43 分钟前
【人工智能】Python在机器学习与人工智能中的应用
开发语言·人工智能·python·机器学习
湫ccc1 小时前
《Python基础》之pip换国内镜像源
开发语言·python·pip
hakesashou1 小时前
Python中常用的函数介绍
java·网络·python
菜鸟的人工智能之路1 小时前
极坐标气泡图:医学数据分析的可视化新视角
python·数据分析·健康医疗
菜鸟学Python1 小时前
Python 数据分析核心库大全!
开发语言·python·数据挖掘·数据分析
小白不太白9501 小时前
设计模式之 责任链模式
python·设计模式·责任链模式
喜欢猪猪1 小时前
Django:从入门到精通
后端·python·django