深入理解Python中的subprocess模块
目录
- subprocess模块简介
- 常用函数
- 执行外部命令
- 管道通信
- 子进程管理
- 错误处理
- 实际应用示例
- 最佳实践
subprocess模块简介
subprocess模块是Python标准库的一部分,提供了一个跨平台的方法来生成新进程、连接其输入/输出/错误管道,并获取其返回码。该模块旨在替代旧的os.system、os.spawn*、os.popen*和commands模块,提供一个更强大和灵活的接口。
常用函数
subprocess模块中有几个常用的函数和类,它们是进行进程管理和管道通信的核心:
subprocess.run()subprocess.Popen()subprocess.call()subprocess.check_call()subprocess.check_output()subprocess.DEVNULLsubprocess.PIPEsubprocess.STDOUT
示例代码
import subprocess# 运行一个命令并等待其完成
subprocess.run(["ls", "-l"])# 使用Popen对象启动和管理进程
process = subprocess.Popen(["ls", "-l"], stdout=subprocess.PIPE)
output, error = process.communicate()
print(output.decode())
执行外部命令
使用subprocess.run()
subprocess.run()是执行外部命令的推荐方式。它接受一个命令序列或字符串,返回一个CompletedProcess实例,包含了命令的执行结果。
示例代码
import subprocess# 执行命令并等待完成
result = subprocess.run(["echo", "Hello, World!"], capture_output=True, text=True)
print(result.stdout)
使用subprocess.call()
subprocess.call()用于执行命令并返回其退出状态。它类似于subprocess.run(),但不会返回CompletedProcess实例。
示例代码
import subprocess# 执行命令并返回退出状态
return_code = subprocess.call(["ls", "-l"])
print(f"Return code: {return_code}")
使用subprocess.check_call()
subprocess.check_call()类似于subprocess.call(),但如果命令返回非零退出状态,它会引发CalledProcessError异常。
示例代码
import subprocesstry:subprocess.check_call(["ls", "-l"])
except subprocess.CalledProcessError as e:print(f"Command failed with return code {e.returncode}")
使用subprocess.check_output()
subprocess.check_output()执行命令并返回其输出。如果命令返回非零退出状态,它会引发CalledProcessError异常。
示例代码
import subprocesstry:output = subprocess.check_output(["echo", "Hello, World!"], text=True)print(output)
except subprocess.CalledProcessError as e:print(f"Command failed with return code {e.returncode}")
管道通信
subprocess模块允许开发者通过管道连接多个进程,实现进程间通信。使用subprocess.PIPE可以将子进程的输入/输出/错误重定向到父进程。
示例代码
import subprocess# 将子进程的输出重定向到父进程
process = subprocess.Popen(["echo", "Hello, World!"], stdout=subprocess.PIPE)
output, error = process.communicate()
print(output.decode())
管道连接示例
import subprocess# 使用管道连接两个命令
p1 = subprocess.Popen(["echo", "Hello, World!"], stdout=subprocess.PIPE)
p2 = subprocess.Popen(["grep", "Hello"], stdin=p1.stdout, stdout=subprocess.PIPE)
p1.stdout.close() # 允许p1关闭它的输出管道
output, error = p2.communicate()
print(output.decode())
子进程管理
终止子进程
可以使用Popen对象的terminate()和kill()方法终止子进程。
示例代码
import subprocess
import time# 启动一个长时间运行的进程
process = subprocess.Popen(["sleep", "10"])# 等待2秒后终止进程
time.sleep(2)
process.terminate()
process.wait()
print("Process terminated")
获取子进程的返回码
可以使用Popen对象的returncode属性获取子进程的返回码。
示例代码
import subprocessprocess = subprocess.Popen(["ls", "-l"], stdout=subprocess.PIPE)
process.wait()
print(f"Return code: {process.returncode}")
错误处理
捕获异常
在执行外部命令时,可能会遇到各种异常情况。subprocess模块提供了CalledProcessError和TimeoutExpired异常,便于开发者处理错误。
示例代码
import subprocesstry:subprocess.check_call(["false"])
except subprocess.CalledProcessError as e:print(f"Command failed with return code {e.returncode}")
超时处理
可以使用timeout参数设置命令的超时时间,如果命令在指定时间内没有完成,将引发TimeoutExpired异常。
示例代码
import subprocesstry:subprocess.run(["sleep", "10"], timeout=5)
except subprocess.TimeoutExpired:print("Command timed out")
实际应用示例
运行shell命令
在实际应用中,subprocess模块常用于运行shell命令。使用shell=True参数可以在shell中执行命令。
示例代码
import subprocessresult = subprocess.run("ls -l | grep .py", shell=True, capture_output=True, text=True)
print(result.stdout)
备份数据库
可以使用subprocess模块执行数据库备份命令,将备份文件保存到指定路径。
示例代码
import subprocesscommand = ["mysqldump", "-u", "root", "-p", "database_name"]
with open("backup.sql", "w") as f:result = subprocess.run(command, stdout=f)if result.returncode == 0:print("Backup successful")else:print("Backup failed")
自动化脚本
subprocess模块可以用于编写自动化脚本,执行一系列的命令完成特定任务。
示例代码
import subprocessdef run_commands(commands):for command in commands:result = subprocess.run(command, shell=True, capture_output=True, text=True)if result.returncode != 0:print(f"Command failed: {command}")print(result.stderr)breakelse:print(result.stdout)commands = ["echo 'Starting automation script'","mkdir -p /tmp/test_directory","touch /tmp/test_directory/test_file","echo 'Automation script completed'"
]run_commands(commands)
最佳实践
- 避免使用
shell=True: 除非必要,否则尽量避免使用shell=True,以减少安全风险。 - 使用完整路径: 在命令中使用完整路径,以确保命令能够正确执行。
- 处理异常: 始终捕获并处理可能出现的异常,确保程序的健壮性。
- 设置超时: 对长时间运行的命令设置超时,以避免程序挂起。
- 使用上下文管理器: 使用上下文管理器管理文件对象,确保资源正确释放。
示例代码
import subprocessdef safe_run_command(command, timeout=10):try:result = subprocess.run(command, capture_output=True, text=True, timeout=timeout)result.check_returncode()return result.stdoutexcept subprocess.CalledProcessError as e:print(f"Command '{e.cmd}' failed with return code {e.returncode}")except subprocess.TimeoutExpired as e:print(f"Command '{e.cmd}' timed out after {e.timeout} seconds")output = safe_run_command(["ls", "-l"])
print(output)
结论
subprocess模块是Python中执行外部命令和管理子进程的强大工具。通过学习并掌握subprocess模块的使用,可以编写出高效、可靠的自动化脚本和系统
管理工具。本文详细介绍了subprocess模块的基本概念、常用函数、管道通信、子进程管理、错误处理及实际应用示例,希望对读者有所帮助。通过不断实践和应用这些知识,开发者能够提高代码质量,减少错误,提升开发效率。
相关文章:
深入理解Python中的subprocess模块
目录 subprocess模块简介常用函数执行外部命令管道通信子进程管理错误处理实际应用示例最佳实践 subprocess模块简介 subprocess模块是Python标准库的一部分,提供了一个跨平台的方法来生成新进程、连接其输入/输出/错误管道,并获取其返回码。该模块旨…...
从零开始搭建 EMQX 集群压测框架
从零开始搭建 EMQX 集群压测框架 架构 在设计以EMQX为中心的MQTT消息队列集群压力测试框架时,我们采用微服务架构模式。EMQX作为消息队列的核心,负责处理MQTT协议的消息发布和订阅。Nginx作为EMQX的反向代理,负责负载均衡和SSL/TLS终端。MQT…...
ArkUI基本介绍
ArkUI:提供HarmonyOS应用UI开发框架,几件开发、精致体验、跨设备/跨平台。 ArkUI(方舟UI框架)为应用的UI开发提供了完整的基础设施,包括简洁的UI语法、丰富的UI功能(组件、布局、动画以及交互事件ÿ…...
vue2+OpenLayers 天地图上打点并且显示相关的信息(2)
上次是在地图上打点 这次鼠标移动在图标上面显示相关的信息 首先有两个事件 鼠标移入 和 鼠标移出事件 pointermove pointerout 鼠标放上去之前 放上去后 代码如下 <template><div class"container"><div id"vue-openlayers" class&quo…...
c++继承(二)
一、友元函数的继承 友元函数不能被继承,就像爸爸的朋友不是你的朋友,如果要有友元函数,在子类重新定义一个。 二、静态成员的继承 静态成员的继承仍然是那个成员,普通成员的继承是不同的。 父类的静态成员属于当前类…...
低代码开发的崛起:机遇与挑战
近年来,“低代码”开发平台的迅速崛起,已经成为IT行业中不可忽视的趋势。这些平台承诺让非专业人士也能快速构建应用程序,通过减少代码编写的需求,大幅提高开发效率。对于许多企业而言,低代码开发工具成为了一个加速数…...
Json-JacksonUtils工具类
为了创建一个通用的 Jackson 工具类,我们可以定义一个名为 JacksonUtils 的工具类,该类将提 供多种方法来支持不同类型的 JSON 转换需求。下面是一个示例实现,包括基本的 JSON 到 Java 对象的转换、Java 对象到 JSON 的转换、以及更复杂的类型如 CommonResult 的转换。 C…...
svn客户端装完后没有svn.exe
如果SVN客户端(如TortoiseSVN)安装完成后,在预期的安装目录(通常是bin目录)中没有找到svn.exe文件,这通常是因为在安装过程中没有选择安装命令行客户端工具(Command Line Client Toolsÿ…...
TinyWebserver的复现与改进(4):主线程的具体实现
GitHub - yzfzzz/MyWebServer: Linux高并发服务器项目,参考了TinyWebServer,将在此基础上进行性能改进与功能增加。为方便读者学习,附带详细注释和博客! TinyWebserver的复现与改进(1):服务器环…...
DaemonSet 不能帮助我们做什么事情?
DaemonSet 不能帮助我们做什么事情? A. 保证集群内每一个(或者一些)节点都运行一组相同的Pod B. 跟踪集群节点状态,保证新加入的节点自动创建对应的Pod C. 跟踪集群节点状态,保证移除的节点删除对应的Pod D. 能够设置Pod重试次数,…...
开源模型应用落地-LangChain高阶-记忆组件-RedisChatMessageHistory正确使用(八)
一、前言 LangChain 的记忆组件发挥着至关重要的作用,其旨在协助大语言模型(LLM)有效地留存历史对话信息。通过这一功能,使得大语言模型在对话过程中能够更出色地维持上下文的连贯性和一致性,进而能够像人类的记忆运作方式那样,进行更为自然、流畅且智能化的交互。 它仿佛…...
解决Openwrt 串口默认是没有密码的方法
将串口登录加入密码方法如下: 步骤一:配置busybox的登录,可以在.config文件中添加如下 CONFIG_BUSYBOX_CONFIG_LOGINy 添加后,需要重新编译busybox。 步骤二:修改target/linux/ramips/base-files/etc/inittab文件 将…...
【vue讲解:v-model 之 lazy、number、trim、与后端交互、小电影案例】
2 v-model 之 lazy、number、trim lazy:等待input框的数据绑定时区焦点之后再变化 number:数字开头,只保留数字,后面的字母不保留;字母开头,都保留 trim:去除首位的空格<!DOCTYPE html> …...
ECCV 2024 | 南洋理工三维数字人生成新范式:结构扩散模型
该论文作者均来自于新加坡南洋理工大学 S-Lab 团队,包括博士后胡涛,博士生洪方舟,以及计算与数据学院刘子纬教授(《麻省理工科技评论》亚太地区 35 岁以下创新者)。S-Lab 近年来在顶级会议如 CVPR, ICCV, ECCV, NeurIP…...
2024.8.13-算法学习(原创+转载)
一、什么是张量并行(Tensor Parallelism) ? 张量并行(Tensor Parallelism) 是一种分布式矩阵算法。 随着模型越来越大,模型内的矩阵也越来越大。一个大矩阵的乘法可以拆分成多个小矩阵的运算,…...
beautifulsoup的简单使用
文章目录 beautifulsoup一. beautifulsoup的简单使用1、安装2、如何使用3、对象的种类 二、beautifulsoup的遍历文档树2.1 子节点.contents 和 .children descendants2.2 节点内容.string.text 2.3 多个内容.strings**.stripped_strings** 2.4 父节点.parent.parents 三、beaut…...
【Python】Jupyter Notebook的安装及简单使用
Jupyter Notebook的安装及简单使用1、安装2、language设置为中文3、Jupyter Notebook启动4、Jupyter Notebook的常用快捷方式5、将Notebook笔记转为其他文件格式保存 Jupyter Notebook的安装及简单使用 不安装AnaCoda,但需要使用Jupyter Notebook 1、安装 pip inst…...
中国自动驾驶出租车冲击网约车市场
近年来,中国的自动驾驶技术迅速发展,对传统网约车市场构成了越来越大的冲击。随着科技巨头百度旗下的萝卜快跑等公司加速推广无人驾驶出租车,这一趋势引发了广泛的讨论和担忧。 自动驾驶技术的迅猛发展 中国自动驾驶行业正处于快速发展阶段&…...
解决浏览器书签同步问题,极空间部署开源免费的跨平台书签同步工具『xBrowserSync』
解决浏览器书签同步问题,极空间部署开源免费的跨平台书签同步工具『xBrowserSync』 哈喽小伙伴们好,我是Stark-C~ 作为一个喜欢折腾的数码党,我平时上网冲浪使用的浏览器绝不会只限于一种,就比如说我在上班的地方只会用到Edge浏…...
14个SpringBoot优化小妙招
今天我们来分享一下平时用SpringBoot开发时候的一些优化小妙招,用好这些优化小妙招让我们开发的系统架构、系统代码、开发流程、测试流程、运维监控看起来就跟写诗一样优雅,让我们每个人手头负责的代码和工程都要很漂亮~~~ 这里的优化小妙招很多不是说直…...
变量 varablie 声明- Rust 变量 let mut 声明与 C/C++ 变量声明对比分析
一、变量声明设计:let 与 mut 的哲学解析 Rust 采用 let 声明变量并通过 mut 显式标记可变性,这种设计体现了语言的核心哲学。以下是深度解析: 1.1 设计理念剖析 安全优先原则:默认不可变强制开发者明确声明意图 let x 5; …...
Java 语言特性(面试系列2)
一、SQL 基础 1. 复杂查询 (1)连接查询(JOIN) 内连接(INNER JOIN):返回两表匹配的记录。 SELECT e.name, d.dept_name FROM employees e INNER JOIN departments d ON e.dept_id d.dept_id; 左…...
Spring Boot+Neo4j知识图谱实战:3步搭建智能关系网络!
一、引言 在数据驱动的背景下,知识图谱凭借其高效的信息组织能力,正逐步成为各行业应用的关键技术。本文聚焦 Spring Boot与Neo4j图数据库的技术结合,探讨知识图谱开发的实现细节,帮助读者掌握该技术栈在实际项目中的落地方法。 …...
【Java学习笔记】BigInteger 和 BigDecimal 类
BigInteger 和 BigDecimal 类 二者共有的常见方法 方法功能add加subtract减multiply乘divide除 注意点:传参类型必须是类对象 一、BigInteger 1. 作用:适合保存比较大的整型数 2. 使用说明 创建BigInteger对象 传入字符串 3. 代码示例 import j…...
A2A JS SDK 完整教程:快速入门指南
目录 什么是 A2A JS SDK?A2A JS 安装与设置A2A JS 核心概念创建你的第一个 A2A JS 代理A2A JS 服务端开发A2A JS 客户端使用A2A JS 高级特性A2A JS 最佳实践A2A JS 故障排除 什么是 A2A JS SDK? A2A JS SDK 是一个专为 JavaScript/TypeScript 开发者设计的强大库ÿ…...
NPOI操作EXCEL文件 ——CAD C# 二次开发
缺点:dll.版本容易加载错误。CAD加载插件时,没有加载所有类库。插件运行过程中用到某个类库,会从CAD的安装目录找,找不到就报错了。 【方案2】让CAD在加载过程中把类库加载到内存 【方案3】是发现缺少了哪个库,就用插件程序加载进…...
Caliper 负载(Workload)详细解析
Caliper 负载(Workload)详细解析 负载(Workload)是 Caliper 性能测试的核心部分,它定义了测试期间要执行的具体合约调用行为和交易模式。下面我将全面深入地讲解负载的各个方面。 一、负载模块基本结构 一个典型的负载模块(如 workload.js)包含以下基本结构: use strict;/…...
Vue ③-生命周期 || 脚手架
生命周期 思考:什么时候可以发送初始化渲染请求?(越早越好) 什么时候可以开始操作dom?(至少dom得渲染出来) Vue生命周期: 一个Vue实例从 创建 到 销毁 的整个过程。 生命周期四个…...
深度学习之模型压缩三驾马车:模型剪枝、模型量化、知识蒸馏
一、引言 在深度学习中,我们训练出的神经网络往往非常庞大(比如像 ResNet、YOLOv8、Vision Transformer),虽然精度很高,但“太重”了,运行起来很慢,占用内存大,不适合部署到手机、摄…...
Linux部署私有文件管理系统MinIO
最近需要用到一个文件管理服务,但是又不想花钱,所以就想着自己搭建一个,刚好我们用的一个开源框架已经集成了MinIO,所以就选了这个 我这边对文件服务性能要求不是太高,单机版就可以 安装非常简单,几个命令就…...
