subprocess库学习之run(函数)

2024-09-01 23:28
文章标签 函数 学习 run subprocess

本文主要是介绍subprocess库学习之run(函数),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

subprocess库学习之run(函数)

一、简介

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

二、语法和参数

语法

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

      import subprocessresult = subprocess.run(['echo', 'Hello, World!'], capture_output=True, text=True)
      print(result.stdout)
      
    • Windows

      import subprocessresult = subprocess.run('echo Hello, World!', shell=True, capture_output=True, text=True)
      print(result.stdout)
      
  • 输出

Hello, World!
3.2 捕获命令的错误输出
  • 代码
import subprocessresult = subprocess.run(['ls', '/nonexistent'], capture_output=True, text=True)
print("Return code:", result.returncode)
print("Error output:", result.stderr)
  • 输出
Return code: 2
Error output: ls: cannot access '/nonexistent': No such file or directory
3.3 使用 shell 运行命令
  • 代码
import subprocessresult = subprocess.run('echo Hello from shell', shell=True, capture_output=True, text=True)
print(result.stdout)
  • 输出
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 的内部命令将可正常执行。

这篇关于subprocess库学习之run(函数)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1128347

相关文章

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

MySQL 中 ROW_NUMBER() 函数最佳实践

《MySQL中ROW_NUMBER()函数最佳实践》MySQL中ROW_NUMBER()函数,作为窗口函数为每行分配唯一连续序号,区别于RANK()和DENSE_RANK(),特别适合分页、去重... 目录mysql 中 ROW_NUMBER() 函数详解一、基础语法二、核心特点三、典型应用场景1. 数据分

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Python get()函数用法案例详解

《Pythonget()函数用法案例详解》在Python中,get()是字典(dict)类型的内置方法,用于安全地获取字典中指定键对应的值,它的核心作用是避免因访问不存在的键而引发KeyError错... 目录简介基本语法一、用法二、案例:安全访问未知键三、案例:配置参数默认值简介python是一种高级编