subprocess模块篇

2024-04-07 12:52
文章标签 模块 subprocess

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

文章目录

  • 使用方法
  • 调用Python程序
  • 设置工作目录

使用方法

subprocess模块是Python中用于生成新的进程,连接到它们的input/output/error管道,并获取它们的返回码的模块1。下面是subprocess模块的一些主要知识点和详细教程:

  • run()方法创建子进程:使用subprocess.run()方法可以方便地创建一个子进程并等待其完成。例如,要运行一个外部命令并获取其输出,可以使用以下代码:
import subprocess
result = subprocess.run(['ls', '-l'], capture_output=True, text=True)
print(result.stdout)

上述代码中,[‘ls’, ‘-l’]是要执行的命令和参数,capture_output=True表示要捕获命令的输出,text=True表示将输出作为文本返回。result.stdout就是命令的输出结果2。

  • stdin, stdout, stderr的配置以及管道使用:subprocess模块允许你配置子进程的stdin, stdout, stderr,并可以通过管道与它们进行通信。例如,要将子进程的输出重定向到一个文件,可以使用以下代码:
import subprocess
with open('output.txt', 'w') as f:subprocess.run(['ls', '-l'], stdout=f)

上述代码中,将子进程的stdout重定向到了文件output.txt中2。

  • Popen API使用:subprocess.Popen类提供了更底层的接口,可以用于创建子进程并进行更复杂的通信。例如,要创建一个子进程并通过管道与其进行通信,可以使用以下代码:
import subprocess
child = subprocess.Popen(['cat', 'input.txt'], stdout=subprocess.PIPE)
output, _ = child.communicate()
print(output.decode('utf-8'))

上述代码中,Popen创建了一个子进程来执行cat命令,并将stdout配置为PIPE,表示要通过管道获取输出。然后通过child.communicate()方法与子进程进行通信,获取输出结果2。

除了以上知识点外,subprocess模块还有许多其他功能和用法,具体可以参考Python官方文档或其他相关教程。

调用Python程序

要使用subprocess模块调用Python程序,你可以使用subprocess.run()或subprocess.Popen()函数。下面是一些示例:
使用subprocess.run()

import subprocess# 调用Python脚本,并等待其完成
result = subprocess.run(['python', 'your_script.py'], capture_output=True, text=True)# 输出脚本的标准输出和错误
print("标准输出:", result.stdout)
print("标准错误:", result.stderr)# 如果需要传递参数给Python脚本,可以这样做:
args = ['arg1', 'arg2', 'arg3']
result = subprocess.run(['python', 'your_script.py'] + args, capture_output=True, text=True)

在这个例子中,[‘python’, ‘your_script.py’]是你要运行的命令和脚本名。capture_output=True和text=True参数使得你可以捕获脚本的输出,并将其作为文本返回。
使用subprocess.Popen()

import subprocess# 使用Popen创建子进程,并与之通信
with subprocess.Popen(['python', 'your_script.py'], stdout=subprocess.PIPE, stderr=subprocess.PIPE, text=True) as proc:stdout, stderr = proc.communicate()# 输出脚本的标准输出和错误
print("标准输出:", stdout)
print("标准错误:", stderr)

在这个例子中,我们使用Popen创建了一个子进程,并通过stdout=subprocess.PIPE和stderr=subprocess.PIPE参数捕获了其标准输出和错误输出。然后,我们使用proc.communicate()方法等待进程完成并获取输出。

请注意,如果你的Python脚本位于不同的目录,你需要提供完整的路径到脚本文件,例如[‘python’, ‘/path/to/your_script.py’]。

另外,如果你使用的是Python 3并且希望使用Python解释器的绝对路径来运行脚本,可以使用sys.executable来获取当前Python解释器的路径:

import sys
import subprocess# 使用当前Python解释器运行脚本
result = subprocess.run([sys.executable, 'your_script.py'], capture_output=True, text=True)

这样可以确保你使用正确的Python版本来运行脚本,即使在系统上安装了多个Python版本的情况下。

设置工作目录

在subprocess.run()函数中,你可以使用cwd参数来设置子进程的工作目录。cwd参数表示子进程运行时的当前工作目录,它接受一个字符串参数,表示目录的路径。

以下是一个使用cwd参数设置工作目录的示例:

import subprocess# 设置子进程的工作目录为/path/to/working_directory
result = subprocess.run(['ls', '-l'], cwd='/path/to/working_directory', capture_output=True, text=True)# 输出子进程在工作目录下的文件列表
print(result.stdout)

在这个例子中,[‘ls’, ‘-l’]命令会在/path/to/working_directory目录下执行,而不是在当前工作目录下执行。capture_output=True和text=True参数使得你可以捕获命令的输出,并将其作为文本返回。

subprocess.run()函数会等待子进程完成,并返回一个CompletedProcess实例,你可以通过这个实例的stdout和stderr属性来获取子进程的标准输出和错误输出。

请注意,你需要确保指定的目录路径是存在的,否则子进程会因为找不到工作目录而失败。如果目录路径不存在,subprocess.run()函数会抛出一个FileNotFoundError异常。

此外,如果你想使用当前Python脚本所在的目录作为子进程的工作目录,你可以使用os.path.dirname(os.path.abspath(file))来获取当前脚本的绝对路径,并使用os.path.dirname()来获取其所在的目录路径。例如:

import os
import subprocess# 获取当前脚本所在的目录路径
script_dir = os.path.dirname(os.path.abspath(__file__))# 设置子进程的工作目录为当前脚本所在的目录
result = subprocess.run(['ls', '-l'], cwd=script_dir, capture_output=True, text=True)# 输出子进程在工作目录下的文件列表
print(result.stdout)

这篇关于subprocess模块篇的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Python中logging模块用法示例总结

《Python中logging模块用法示例总结》在Python中logging模块是一个强大的日志记录工具,它允许用户将程序运行期间产生的日志信息输出到控制台或者写入到文件中,:本文主要介绍Pyt... 目录前言一. 基本使用1. 五种日志等级2.  设置报告等级3. 自定义格式4. C语言风格的格式化方法

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

Nginx添加内置模块过程

《Nginx添加内置模块过程》文章指导如何检查并添加Nginx的with-http_gzip_static模块:确认该模块未默认安装后,需下载同版本源码重新编译,备份替换原有二进制文件,最后重启服务验... 目录1、查看Nginx已编辑的模块2、Nginx官网查看内置模块3、停止Nginx服务4、Nginx

python urllib模块使用操作方法

《pythonurllib模块使用操作方法》Python提供了多个库用于处理URL,常用的有urllib、requests和urlparse(Python3中为urllib.parse),下面是这些... 目录URL 处理库urllib 模块requests 库urlparse 和 urljoin编码和解码

创建springBoot模块没有目录结构的解决方案

《创建springBoot模块没有目录结构的解决方案》2023版IntelliJIDEA创建模块时可能出现目录结构识别错误,导致文件显示异常,解决方法为选择模块后点击确认,重新校准项目结构设置,确保源... 目录创建spChina编程ringBoot模块没有目录结构解决方案总结创建springBoot模块没有目录

idea Maven Springboot多模块项目打包时90%的问题及解决方案

《ideaMavenSpringboot多模块项目打包时90%的问题及解决方案》:本文主要介绍ideaMavenSpringboot多模块项目打包时90%的问题及解决方案,具有很好的参考价值,... 目录1. 前言2. 问题3. 解决办法4. jar 包冲突总结1. 前言之所以写这篇文章是因为在使用Mav

Python标准库datetime模块日期和时间数据类型解读

《Python标准库datetime模块日期和时间数据类型解读》文章介绍Python中datetime模块的date、time、datetime类,用于处理日期、时间及日期时间结合体,通过属性获取时间... 目录Datetime常用类日期date类型使用时间 time 类型使用日期和时间的结合体–日期时间(

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Python中re模块结合正则表达式的实际应用案例

《Python中re模块结合正则表达式的实际应用案例》Python中的re模块是用于处理正则表达式的强大工具,正则表达式是一种用来匹配字符串的模式,它可以在文本中搜索和匹配特定的字符串模式,这篇文章主... 目录前言re模块常用函数一、查看文本中是否包含 A 或 B 字符串二、替换多个关键词为统一格式三、提

一文深入详解Python的secrets模块

《一文深入详解Python的secrets模块》在构建涉及用户身份认证、权限管理、加密通信等系统时,开发者最不能忽视的一个问题就是“安全性”,Python在3.6版本中引入了专门面向安全用途的secr... 目录引言一、背景与动机:为什么需要 secrets 模块?二、secrets 模块的核心功能1. 基