Python Subprocess教程:创建和管理子进程的完整指南

news2024/11/24 4:55:48

66ac829753c02f32d1eddffaafe9c9b3.jpeg

更多Python学习内容:ipengtao.com

在Python中,Subprocess模块为我们提供了强大的工具,使得创建和管理子进程变得十分便捷。本文将深入探讨Subprocess的各种功能和用法,通过丰富的示例代码,带你领略其强大的子进程管理能力。

基本使用

首先,了解如何基本使用Subprocess模块来执行外部命令。

import subprocess

result = subprocess.run(["echo", "Hello, Subprocess!"], capture_output=True, text=True)
print(result.stdout)
# 输出: Hello, Subprocess!

处理输入和输出

Subprocess允许与子进程进行交互,处理输入和输出流。

input_data = "Input for the subprocess"
result = subprocess.run(["echo"], input=input_data, capture_output=True, text=True)
print(result.stdout)
# 输出: Input for the subprocess

错误处理

处理子进程中的错误信息是使用Subprocess的一个关键方面。

result = subprocess.run(["ls", "nonexistent_folder"], capture_output=True, text=True)
if result.returncode != 0:
    print(f"Error: {result.stderr}")
# 输出: Error: ls: cannot access 'nonexistent_folder': No such file or directory

管道和串联命令

Subprocess允许创建管道,串联多个命令的输出和输入。

result = subprocess.run("echo Hello | wc -c", shell=True, capture_output=True, text=True)
print(result.stdout)
# 输出: 6

并行执行多个命令

使用Subprocess,可以并行执行多个命令。

commands = ["echo Hello", "echo World"]
processes = [subprocess.Popen(cmd, shell=True, stdout=subprocess.PIPE) for cmd in commands]
outputs = [p.communicate()[0] for p in processes]
print(outputs)
# 输出: [b'Hello\n', b'World\n']

超时处理

设置超时时间是确保子进程不会无限期地运行的一种方式。

try:
    result = subprocess.run(["sleep", "10"], timeout=5, check=True)
except subprocess.TimeoutExpired:
    print("Process timed out.")

异步执行

使用Subprocess的异步方法,可以实现非阻塞的子进程执行。

import asyncio

async def run_command():
    process = await asyncio.create_subprocess_shell("echo Hello, Async Subprocess!", stdout=asyncio.subprocess.PIPE, text=True)
    output, _ = await process.communicate()
    print(output)

asyncio.run(run_command())
# 输出: Hello, Async Subprocess!

交互式子进程

在需要与子进程进行交互的情况下,Subprocess也提供了强大的解决方案。

process = subprocess.Popen(["python"], stdin=subprocess.PIPE, stdout=subprocess.PIPE, text=True)
process.stdin.write("print('Hello from interactive subprocess')\n")
output, _ = process.communicate()
print(output)
# 输出: Hello from interactive subprocess

子进程环境变量

通过Subprocess,可以方便地设置和使用子进程的环境变量。

custom_env = {"CUSTOM_VARIABLE": "Custom Value"}
result = subprocess.run(["echo", "$CUSTOM_VARIABLE"], env=custom_env, shell=True, capture_output=True, text=True)
print(result.stdout)
# 输出: Custom Value

创建和管理进程组

Subprocess允许创建和管理进程组,以及向组发送信号。

import os

process = subprocess.Popen(["sleep", "60"])
os.killpg(os.getpgid(process.pid), signal.SIGTERM)

子进程的权限管理

Subprocess模块还提供了对子进程的权限管理,包括以不同的用户身份运行子进程。

result = subprocess.run(["ls", "/root"], capture_output=True, text=True, check=True, preexec_fn=os.seteuid(0))
print(result.stdout)
# 输出: (root目录下的文件列表)

子进程的工作目录

可以指定子进程的工作目录,确保子进程在指定目录下执行操作。

result = subprocess.run(["pwd"], capture_output=True, text=True, check=True, cwd="/path/to/directory")
print(result.stdout)
# 输出: /path/to/directory

跨平台兼容性

Subprocess模块在不同平台上表现一致,使得代码可以轻松地在不同操作系统上执行。

result = subprocess.run(["echo", "Hello, Subprocess!"], capture_output=True, text=True)
print(result.stdout)
# 输出: Hello, Subprocess!

安全性考虑

在实际应用中,需要注意对子进程的输入进行有效的验证和处理,以防止安全漏洞。

user_input = input("Enter a command: ")
result = subprocess.run(user_input, shell=True, capture_output=True, text=True)
print(result.stdout)

与其他Python模块结合

Subprocess模块可以与其他Python模块集成,例如与正则表达式模块re结合,处理子进程输出。

import re

result = subprocess.run(["ls", "-l"], capture_output=True, text=True)
file_permissions = re.findall(r"(\S+\s+){2}(\S+)", result.stdout)
print(file_permissions)

总结

在本篇文章中,全面探讨了Python中Subprocess模块的各种功能和用法,提供了丰富的示例代码,使大家能够更加深入地理解和灵活运用该模块。从基本的命令执行到处理输入输出、错误处理、并行执行、超时处理,再到异步执行和交互式子进程,以及权限管理、工作目录指定、跨平台兼容性和安全性考虑等高级主题,我们全方位展示了Subprocess的强大功能。

Subprocess模块在处理子进程相关任务时展现出极大的灵活性和实用性,适用于多种场景,包括系统管理、任务自动化、并行执行和与其他Python模块的集成。通过深入学习Subprocess,能够更自如地应对复杂的进程管理需求,提高代码的效率和可维护性。

总的来说,Subprocess模块为Python开发者提供了强大的工具,使得子进程的创建、管理和与之交互变得轻松而高效。通过实际的示例和场景,本文旨在帮助大家更全面地掌握Subprocess模块,使其能够熟练应对实际项目中的各种子进程管理任务,为编写稳健、高效的Python代码打下坚实基础。

如果你觉得文章还不错,请大家 点赞、分享、留言 下,因为这将是我持续输出更多优质文章的最强动力!

更多Python学习内容:ipengtao.com

干货笔记整理

  100个爬虫常见问题.pdf ,太全了!

Python 自动化运维 100个常见问题.pdf

Python Web 开发常见的100个问题.pdf

124个Python案例,完整源代码!

PYTHON 3.10中文版官方文档

耗时三个月整理的《Python之路2.0.pdf》开放下载

最经典的编程教材《Think Python》开源中文版.PDF下载

2945e6a0b629cb1f14e11eb5c62a233f.png

点击“阅读原文”,获取更多学习内容

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1260906.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Compensated Summation/Kahan‘s Summation的理解

阅读《Efficient Generation of Error-Inducing Floating-Point Inputs via Symbolic Execution》这篇论文时,文中提到的Commpensated Summation没看太懂,代码如下: 查阅资料发现Compensated Summation也叫Kahan’s Summation,该…

自己动手实现一个深度学习算法——七、卷积神经网络

文章目录 1.整体结构2.卷积层1)全连接层存在的问题2)卷积运算3)填充4)步幅5)3维数据的卷积运算6)结合方块思考7)批处理 3.池化层1)池化层的特征 4.卷积层和池化层的实现1&#xff09…

C Primer Plus讲解前置说明

说明 本来是准备接着写下去,写着就发现思路整理的有点杂乱无章。果然是“想一千次,不如去做一次”。所以这次准备基于《C Primer Plus》第六版给大家分享一下,也是自己梳理的一个过程。有关C语言的书很多,我选这本也恰巧是因为以前…

7种SQL进阶用法【转】

1.自定义排序(ORDER BY FIELD) 在MySQL中ORDER BY排序除了可以用ASC和DESC之外,还可以使使用自定义排序方式来实现 CREATE TABLE movies ( id INT PRIMARY KEY AUTO_INCREMENT, movie_name VARCHAR(255), actors VARCHAR(255), price DECIMAL(10,2) DEFAULT 50, release date…

L4级智能驾驶公交量产方案

1、自动驾驶分级 2、L4级自动驾驶技术方案 3、线控底盘 4、整车传感器方案 5、自动驾驶能力 6、运控平台

在Linux中对Docker中的服务设置自启动

先在Linux中安装docker,然后对docker中的服务设置自启动。 安装docker 第一步,卸载旧版本docker。 若系统中已安装旧版本docker,则需要卸载旧版本docker以及与旧版本docker相关的依赖项。 命令:yum -y remove docker docker-c…

【Docker】python flask 项目如何打包成 Docker images镜像 上传至阿里云ACR私有(共有)镜像仓库 集成Drone CI

一、Python环境编译 1、处理好venv环境 要生成正常的 requirements.txt 文件,我们就需要先将虚拟环境处理好 创建虚拟环境(可选): 在项目目录中,你可以选择使用虚拟环境,这样你的项目依赖将被隔离在一个…

Java 基础学习(二)运算符与分支流程控制

1 运算符 1.1 运算符概述 1.1.1 运算符概述 运算符是一种告诉计算机执行特定的数学或逻辑等操作的符号。Java运算符号包括:数学运算符、关系运算符、逻辑运算符、赋值运算符号、字符串连接运算符。计算机本质上只能处理数字,处理数字的最常见的方式就…

java学习part15单例模式

107-面向对象(高级)-单例设计模式与main()的理解_哔哩哔哩_bilibili 1.单例 就是说在某些开发场景中,某个类只要有一个对象就足够使用了,不需要重复创建。 (理解:比如说是数据库对象,使用时创建一个可以处理所有的数…

虹科干货 | 适用于基于FPGA的网络设备的IEEE 1588透明时钟架构

导读:在基于FPGA的网络设备中,精确的时间同步至关重要。IEEE 1588标准定义的精确时间协议(PTP)为网络中的设备提供了纳秒级的时间同步。本文将介绍虹科提供的适用于基于FPGA的网络设备的IEEE 1588透明时钟(TC&#xff…

电机伺服驱动学习笔记(6)PID算法

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 文章目录 前言一、连续PID二、参数整定1.一般调节法 工具提示参考文献 前言 提示:本文是根据野火科技电机系列教学视频PID算法的通俗解说和参数整定视频课章节整…

C#文件夹基本操作(判断文件夹是否存在、创建文件夹、移动文件夹、删除文件夹以及遍历文件夹中的文件)

目录 一、判断文件夹是否存在 1.Directory类的Exists()方法 2. DirectoryInfo类的Exists属性 二、创建文件夹 1. Directory类的CreateDirectory()方法 2.DirectoryInfo类的Create()方法 三、移动文件夹 1. Directory类的Move()方法 2.DirectoryInfo类的MoveT…

Unity Meta Quest 一体机开发(八):实现 Hand Grab 扔物体功能

文章目录 📕教程说明📕设置刚体和碰撞体📕给物体添加 Physics Grabbable 脚本📕给手部添加 Hand Velocity Calculator 物体 此教程相关的详细教案,文档,思维导图和工程文件会放入 Seed XR 社区。这是一个高…

预览功能实现

<!-- 预览 --><el-dialog title"预览" :visible.sync"dialogPreviewVisible" width"50%" append-to-body :close-on-click-modal"false" close"PreviewClose"><div style"margin-bottom:5%">&l…

红黑树(万字图文详解)

红黑树 1. 红黑树的概念2. 红黑树的性质3. 红黑树节点的定义4. 红黑树结构5. 红黑树的插入操作5.1 按照二叉搜索的树规则插入新节点5.2 检测新节点插入后&#xff0c;红黑树的性质是否造到破坏5.2.1 情况一: cur为红&#xff0c;p为红&#xff0c;g为黑&#xff0c;u存在且为红…

【日常总结】Swagger 3.0 + 集成 knife4j ,并设置header入参

一、场景 环境&#xff1a; 二、问题 思路 &#xff1a; 三、解决方案 &#xff08;推荐&#xff09; Stage 1&#xff1a;接入knife4j 依赖 Stage 2&#xff1a;修改 yaml 配置 Stage 3&#xff1a;修改 swagger 3 配置文件 Stage 4&#xff1a;查看效果 Swagger UI …

Junos webauth_operation.php 文件上传漏洞复现(CVE-2023-36844)

0x01 产品简介 Junos 是 Juniper Networks 生产的一款可靠的高性能网络操作系统。 0x02 漏洞概述 Junos webauth_operation.php接口处存在文件上传漏洞&#xff0c;未经身份认证的攻击者可利用 Junos 操作系统的 J-Web 服务 /webauth_operation.php 路由上传 php webshell&…

LVS-DR实验

实验前准备 DR服务器&#xff1a;192.168.188.11 192.168.188.15 NFS服务器&#xff1a;192.168.188.14 Web服务器1&#xff1a;192.168.188.12 Web服务器2&#xff1a;192.168.188.13 Vip&#xff1a;192.168.188.188 客户端&#xff1a;192.168.188.200 配置负载均衡调度…

05-学成在线课程分类查询

课程分类查询 界面原型 在新增课程基本信息界面中课程等级、课程类型、课程分类三处信息需要用户选择 当我们点击新增课程时,前端会请求内容管理服务中的content/course-category/tree-nodes接口获取课程分类表中的课程分类信息 响应数据模型 课程分类表course_category是一…

文件权限中 chmod、u+x、u、r、w、x分别代表什么

Linux系统中的每个文件和目录都有访问许可权限&#xff0c;如下面所示&#xff1a; 要说清楚问题&#xff0c;我们截取一些内容&#xff1a; ypyubuntu:~$ ls -l drwxr-xr-- 2 ypy ypy 4096 Nov 30 18:33 Desktop/ drwxr-xr-- 2 ypy ypy 4096 Nov 30 18:33 Documen…