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

相关文章

多模块的springboot项目发布指定模块的脚本方式

《多模块的springboot项目发布指定模块的脚本方式》该文章主要介绍了如何在多模块的SpringBoot项目中发布指定模块的脚本,作者原先的脚本会清理并编译所有模块,导致发布时间过长,通过简化脚本... 目录多模块的springboot项目发布指定模块的脚本1、不计成本地全部发布2、指定模块发布总结多模

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

python subprocess.run中的具体使用

《pythonsubprocess.run中的具体使用》subprocess.run是Python3.5及以上版本中用于运行子进程的函数,它提供了更简单和更强大的方式来创建和管理子进程,本文就来详细... 目录一、详解1.1、基本用法1.2、参数详解1.3、返回值1.4、示例1.5、总结二、subproce

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit

Python模块导入的几种方法实现

《Python模块导入的几种方法实现》本文主要介绍了Python模块导入的几种方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录一、什么是模块?二、模块导入的基本方法1. 使用import整个模块2.使用from ... i

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

深入探索协同过滤:从原理到推荐模块案例

文章目录 前言一、协同过滤1. 基于用户的协同过滤(UserCF)2. 基于物品的协同过滤(ItemCF)3. 相似度计算方法 二、相似度计算方法1. 欧氏距离2. 皮尔逊相关系数3. 杰卡德相似系数4. 余弦相似度 三、推荐模块案例1.基于文章的协同过滤推荐功能2.基于用户的协同过滤推荐功能 前言     在信息过载的时代,推荐系统成为连接用户与内容的桥梁。本文聚焦于

Jenkins构建Maven聚合工程,指定构建子模块

一、设置单独编译构建子模块 配置: 1、Root POM指向父pom.xml 2、Goals and options指定构建模块的参数: mvn -pl project1/project1-son -am clean package 单独构建project1-son项目以及它所依赖的其它项目。 说明: mvn clean package -pl 父级模块名/子模块名 -am参数

寻迹模块TCRT5000的应用原理和功能实现(基于STM32)

目录 概述 1 认识TCRT5000 1.1 模块介绍 1.2 电气特性 2 系统应用 2.1 系统架构 2.2 STM32Cube创建工程 3 功能实现 3.1 代码实现 3.2 源代码文件 4 功能测试 4.1 检测黑线状态 4.2 未检测黑线状态 概述 本文主要介绍TCRT5000模块的使用原理,包括该模块的硬件实现方式,电路实现原理,还使用STM32类