用Python执行程序的4种方式

时间:2023-01-13
本文章向大家介绍用Python执行程序的4种方式,主要内容包括使用 os.system()、使用 os.popen()、使用 subprocess.open()、subprocess.Popen() 的参数解释:、使用subprocess.call()、总结、使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

在编写代码中,经常会遇到在 Python程序中打开外部程序的需求,那么在Python里如何打开外部程序呢?今天我们来介绍四种不同的方式,供大家参考收藏。

使用 os.system()

os.system(command)是最简单的一种方式,我们import os模块,并调用它的system() 方法即可。

参考以下例子:

通过简单两行代码即可在我的电脑上打开 qq程序,因为我是在MacOS 系统里,所以需要在可执行文件之前加一个open,如果是 windows只需要填写可执行文件的绝对路径即可。

现在我们可以调用稍微复杂一点的命令,实现在 Python中调用ping命令

不过os.system()的缺点是无法获取调用后的返回结果,只能通过:

os.system("ping  > result.txt") 这样的方式把结果管道输出到本地文件里。

system的返回值只会有0(成功),1和2表示失败。

总结起来 system()一共干了三件事情:

  1. 从主进程中fork一个子进程。
  2. 在子进程中调用python的exec函数去执行命令。
  3. 在主进程中调用wait(阻塞)等待子进程结束。

如果 对于fork失败,system()函数返回-1。

使用 os.popen()

os.popen(command) 的调用方式和os.system()类似,不过它是通过创建一个管道的方式来fork子进程实现调用程序的。

我们可以通过读取popen的返回对象,以便获取执行结果。

以上代码我们可以发现对返回对象执行read()方法即可获取程序执行后的返回结果。

使用 subprocess.open()

subprocess这个模块在Python用于产生子进程,可以连接子进程的标准输入输出,并且可以得到子进程的返回值。

以下是subprocess.Popen()模块的参数定义:

subprocess.Popen() 的参数解释:

以下通过subprocess.Popen() 执行tree命令,树形结构显示当前程序路径下的所有文件和目录

Popen的参数可以是字符串(string),也可以是列表(list)。

参考两个以下例子:

subprocess.Popen(["cat","test.md"])
subprocess.Popen("cat test.txt", shell=True)

Popen()还有更多的高级用法,欢迎参考官方文档进行学习。

使用subprocess.call()

subporcess模块还有一个call() 方法,可以用于更加简单的调用外部命令。

subprocess.call (*popenargs , **kwargs )

call的使用方法和Popen基本一致,没有太大的区别,在这里只是多介绍一种使用方式。

总结

os.system()用于简单执行命令,可以显示执行结果。

os.popen()用于简单执行命令,不能显示执行结果,可以通过变量返回执行结果。

subprocess.Popen() 用于执行复杂命令,可以显示执行结果,可以设置输出内容。

subprocess.call() 用于执行复杂命令,可以显示执行结果,可以设置输出内容。

 

来源:https://zhuanlan.zhihu.com/p/106487831

原文地址:https://www.cnblogs.com/xuxiaobo/p/17049226.html