ubprocess包主要功能是运行外部的命令和程序。从这个意义上来说,subprocess的功能与shell类似。

subprocess以及经常使用的封装函数

当我们执行python的时候,我们都是在创建并执行一个进程。

在Python中。我们通过标准库中的subprocess包来fork一个子进程,并执行一个外部的程序。



subprocess包中定义有数个创建子进程的函数。这些函数分别以不同的方式创建子进程。所以我们能够依据须要来从中选取一个使用。

另外subprocess还提供了一些管理标准流(standard stream)和管道(pipe)的工具,从而在进程间使用文本通信。



使用subprocess包中的函数创建子进程的时候,要注意:

1) 在创建子进程之后,父进程是否暂停,并等待子进程执行。

2) 函数返回什么

3) 当returncode不为0时,父进程怎样处理。



subprocess.call()

父进程等待子进程完毕

返回退出信息(returncode。相当于exit code)



subprocess.check_call()

父进程等待子进程完毕

返回0

检查退出信息,假设returncode不为0,则举出错误subprocess.CalledProcessError,

该对象包括有returncode属性,可用try…except…来检查。

subprocess.check_output()

父进程等待子进程完毕

返回子进程向标准输出的输出结果

检查退出信息,假设returncode不为0,则举出错误subprocess.CalledProcessError。

该对象包括有returncode属性和output属性,output属性为标准输出的输出结果。可用try…except…来检查。

这三个函数的用法相类似,以subprocess.call()来说明:

import subprocess

rc = subprocess.call(["ls","-l"])

将程序名(ls)和所带的參数(-l)一起放在一个表中传递给subprocess.call()



能够通过一个shell来解释一整个字符串:

  1. import subprocess
  2. import subprocess
  3. child = subprocess.Popen(["ping","-c","5","www.google.com"])
  4. print("parent process")

  1. out = subprocess.call("ls -l", shell=True)
  2. out = subprocess.call("cd ..", shell=True)

使用了shell=True这个參数,这个时候,我们使用一整个字符串,而不是一个表来执行子进程。

Python将先执行一个shell。再用这个shell来解释这整个字符串。

shell命令中有一些是shell的内建命令,这些命令必须通过shell执行。$cd。shell=True同意我们执行这样一些命令。



Popen()

实际上,我们上面的三个函数都是基于Popen()的封装(wrapper)。这些封装的目的在于让我们easy使用子进程。

当我们想要更个性化我们的需求的时候。就要转向Popen类,该类生成的对象用来代表子进程。



与上面的封装不同。Popen对象创建后。主程序不会自己主动等待子进程完毕。

我们必须调用对象的wait()方法。父进程才会等待 (也就是堵塞block):



从执行结果中看到,父进程在开启子进程之后并没有等待child的完毕。而是直接执行print。

对照等待的情况:

  1. import subprocess
  2. child = subprocess.Popen(["ping","-c","5","www.google.com"])
  3. child.wait()
  4. print("parent process")

此外。你还能够在父进程中对子进程进行其他操作,比方我们上面样例中的child对象:

child.poll()           # 检查子进程状态

child.kill()           # 终止子进程

child.send_signal()    # 向子进程发送信号

child.terminate()      # 终止子进程



子进程的PID存储在child.pid



子进程的文本流控制

子进程的标准输入,标准输出和标准错误也能够通过例如以下属性表示:

child.stdin

child.stdout

child.stderr

我们能够在Popen()建立子进程的时候改变标准输入、标准输出和标准错误。

并能够利用subprocess.PIPE将多个子进程的输入和输出连接在一起,构成管道(pipe):

  1. import subprocess
  2. child1 = subprocess.Popen(["ls","-l"], stdout=subprocess.PIPE)
  3. child2 = subprocess.Popen(["wc"], stdin=child1.stdout,stdout=subprocess.PIPE)
  4. out = child2.communicate()
  5. print(out)

subprocess.PIPE实际上为文本流提供一个缓存区。

child1的stdout将文本输出到缓存区,随后child2的stdin从该PIPE中将文本读取走。

child2的输出文本也被存放在PIPE中,直到communicate()方法从PIPE中读取出PIPE中的文本。

要注意的是。communicate()是Popen对象的一个方法,该方法会堵塞父进程,直到子进程完毕。



我们还能够利用communicate()方法来使用PIPE给子进程输入:

  1. import subprocess
  2. child = subprocess.Popen(["cat"], stdin=subprocess.PIPE)
  3. child.communicate("vamei")

我们启动子进程之后,cat会等待输入,直到我们用communicate()输入”vamei”。



通过使用subprocess包。我们能够执行外部程序。

这极大的拓展了Python的功能。

假设你已经了解了操作系统的某些应用。你能够从Python中直接调用该应用(而不是全然依赖Python)。并将应用的结果输出给Python,并让Python继续处理。

shell的功能(比方利用文本流连接各个应用)。就能够在Python中实现。

Python学习笔记13:标准库之子进程(subprocess包)的更多相关文章

  1. Python标准库06 子进程 (subprocess包)

    这里的内容以Linux进程基础和Linux文本流为基础.subprocess包主要功能是执行外部的命令和程序.比如说,我需要使用wget下载文件.我在Python中调用wget程序.从这个意义上来说, ...

  2. python 学习笔记 13 -- 经常使用的时间模块之time

    Python 没有包括相应日期和时间的内置类型.只是提供了3个相应的模块,能够採用多种表示管理日期和时间值: *    time 模块由底层C库提供与时间相关的函数.它包括一些函数用于获取时钟时间和处 ...

  3. C++ Primer学习笔记2--c++标准库中的 vector、string 和 bitset 类型

    一.string    #include <string>  using std::string    初始化函数:    string s1;        默认构造函数 s1 为空串 ...

  4. C++ Primer 学习笔记_6_标准库类型 -- 命名空间using与string类型

     标准库类型(一) --命名空间using与string类型 引: 标准库类型是语言组成部分中更主要的哪些数据类型(如:数组.指针)的抽象! C++标准库定义的是高级的抽象数据类型: 1.高级:由 ...

  5. python学习23之标准库

    '''''''''标准库1.datetime 日期时间模块存在于Lib/datetime.py文件内'''from datetime import datetime,date,time #from d ...

  6. Python 3 学习笔记之——标准库概述

    1. 操作系统接口 os 模块提供了一些与操作系统相关联的函数. >>> os.getcwd() # 获取当前工作目录 '/home/senius' >>> os. ...

  7. Python 学习笔记13:Python + wsgi + django 配置。坑爹的python3和wsgi不兼容的解决

    今人不见古时月,今月曾经照古人.生命是如此的美丽与短暂! 学习Python已经两个月了,Python的语法通过做简单的语法题和看Python语法介绍,有了初步的了解.但上班还是要做别的事情,所以感觉学 ...

  8. python学习笔记(13):python并发编程以及系统常用模块

    一.进程与线程 1.进程:程序的一次执行(程序装载入内存,系统分配资源运行).n 每个进程有自己的内存空间.数据栈等,只能使用进程间通讯,而不能直接共享信息 2.线程:所有线程运行在同一个进程中,共享 ...

  9. 吴裕雄--天生自然python学习笔记:beautifulsoup库的使用

    Beautiful Soup 库简介 Beautiful Soup提供一些简单的.python式的函数用来处理导航.搜索.修改分析树等功能.它是一个工具箱,通过解析文档为用户提供需要抓取的数据,因为简 ...

随机推荐

  1. Java 8 实战 P1 Fundamentals

    目录 Chapter 1. Java 8: why should you care? Chapter 2. Passing code with behavior parameterization Ch ...

  2. [Apple开发者帐户帮助]六、配置应用服务(2)创建DeviceCheck私钥

    要验证与DeviceCheck服务的通信,您将使用启用了DeviceCheck的私钥. 首先创建并下载启用了DeviceCheck 的私钥.然后获取密钥标识符(kid)以创建JSON Web令牌(JW ...

  3. selenium3 + python - gird分布式(转载)

    本篇转自博客:上海-小T 转载链接:https://blog.csdn.net/real_tino/article/details/53467406 Selenium grid是用来分布式执行测试用例 ...

  4. idea常用快捷键(转)

    ---恢复内容开始--- IntelliJ Idea 常用快捷键列表 Ctrl+Shift + Enter,语句完成 “!”,否定完成,输入表达式时按 “!”键 Ctrl+E,最近的文件 Ctrl+S ...

  5. rabbitmq普通集群搭建详细步骤

    由于工作需求,需要安装rabbitmq,学习之余,记录一下安装过程 准备基础编译环境yum install gcc glibc-devel make ncurses-devel openssl-dev ...

  6. Windows phone开发 页面布局之屏幕方向

    (博客部分内容参考Windows phone开发文档) Windows phone的屏幕方向是利用Windows phone设备的方向传感器提供的数据实现切换的. Windows Phone支持纵向和 ...

  7. javascript跨域的几种方法

    以下的例子包含的文件均为为 http://www.a.com/a.html .http://www.a.com/c.html 与 http://www.b.com/b.html,要做的都是从a.htm ...

  8. Java冒泡,快速,插入,选择排序^_^+二分算法查找

    这段时间在学Java,期间学到了一些排序和查找方法.特此写来和大家交流,也方便自己的日后查看与复习. 1.下边是Java的主类: public class Get { public static vo ...

  9. Deutsch lernen (07)

    1. die Einführung, -en 介绍:引言,导论 Könnten Sie uns zuerst eine kleine Einführung über das Klonen geben. ...

  10. python 爬取妹子

    爬取妹子图片 网址:https://www.mzitu.com/jiepai/ 2019-06-13 环境WIN10 1903 python 3.7.3 个人习惯先在IDLE中进行调试 import ...