大家好,今天来介绍subprocess.call的用法(python安装第三方库)的问题,以下是渲大师小编对此问题的归纳和整理,感兴趣的来一起看看吧!
Python Shell 怎样清屏
Python Shell中橘铅清屏一般有两种方法。
1、使用os模块
importos #加载os模块
os.system("cls")#windows上执行cls命令
os.system("clear")#linux上执行clear命令
上图是linux上的示例,扒碧按下回车键后,马上清除所有显示内容。
2、使用subprocess模块
importsubprocess#加载subprocess模块
subprocess.call("clear")#linux上借助于call执行clear命令
subprocess.call("cls",shell=True)#windows上执行cls命令
上图春伍举是linux上的示例,按下回车键后,马上清除所有显示内容。
python打开第三方应用
最近需要写测试pc端的c/s软件的脚本,需要打开要测试的.exe结尾的程序,刚写的时候就遇到了一点问题,就是打开之后,没有执行后面的脚本,直到解决后,重新看了一下这方面的知识,特此记录一下
(1)第一种方式
import os
os.system("要运行的.exe的路径")
这种方式就是在主友没扒线程中运行一个子进程,子进程去执行命令察埋,主进程调用wait阻塞等待子进程进程结束
我启动要测试的.exe后,要进行后面的一系列操作,当我用这种方式后,python脚本就不往下好昌执行了除非结束主进程
(2)接着又尝试了另一种方式
import subprocess
subprocess.call("要运行的.exe的路径")
还是不行,主要是主进程打开新的窗口,原窗口进入休眠状态,待新的窗口关闭,主进程再重新唤醒原窗口
(3)最后选择使用
import os
os.startfile("你要调用的.exe')
备注:
主进程创建一个子进程去打新的窗口,主进程创建完成子进程后立即继续往下执行
命令解释:
os.system()用于简单执行命令,可以显示执行结果。
os.popen()用于简单执行命令,不能显示执行结果,可以通过变量返回执行结果。
subprocess.Popen() 用于执行复杂命令,可以显示执行结果,可以设置输出内容。
subprocess.call() 用于执行复杂命令,可以显示执行结果,可以设置输出内容
python 怎么启动一个外部命令程序并且不阻塞当前进程
在Python中,我们通过标准库中的subprocess包来fork一个子进程,并运行一个外部的程序。
使用subprocess包中的函数创建子进程的时候,要注意:
1) 在创建子进程之后,父卜段液进程是否暂停,并等待子进程运行。
2) 函数返回什么
3) 当returncode不为0时,父进程如何处理。
subprocess.call()
父进程等待子进程完成
返回退出信息
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()来说明:
importsubprocess
rc=subprocess.call(["ls","-l"])
实际上,我们上面的三个函数都是基于Popen()的封装(wrapper)。这些封装的目的在于让我们容易使用子进程。当我们想要更个性化我们的需求的时候,就要转向Popen类,该类生成的对象用来代表子进程。
与上面的封装不同,Popen对象创建后,主程序不会自动等待子进程完成。我们必须调用对象的wait()方法,父进程才会等待 (也就是阻塞block):
importsubprocess
child=subprocess.Popen(["ping","-c","5","www.google.com"])
child.wait()
print("parentprocess")
此外,你还可以在父进型物程中对子进程进行其它操作,比如我们上面例子中的child对象:
child.poll() # 检查子进程状态
child.kill() # 终止子进程
child.send_signal()# 向子进程发送信号
child.terminate() # 终止子进程
因此,如果不希望当前进程被阻塞,你可燃悄以使用Popen对象进行操作。
python中如何调用tcl脚本
1.确保桐旅perl已经安装并做轮伏且纯携在PATH中。
2.in python:
import subprocess
subprocess.call(["perl", "/path/to/your-script.pl"])
如果脚本本身有可执行权限,直接这样也行:
import subprocess
subprocess.call(["/path/to/your-script.pl"])
python subprocess替代哪些模块
subprocess
可以执行shell命令的相关模块和函数有:
os.system
os.spawn
os.popen--废弃
popen2.* --废弃
commands.* --废弃,3.x中被移除
import commands
result = commands.getoutput('cmd') #只返回执行的结果, 忽略返回值.result = commands.getstatus('cmd') #返回ls -ld file执行的结没李果.result = commands.getstatusoutput('cmd')
#用os.popen()执行命令cmd, 然后返回两个元素的元组(status, result). cmd执行的方式是{ cmd ; }2>&1, 这样返回结果里面就会包含标准输出和标准错误.
例子
>>> subprocess.getstatusoutput('pwd')
(0, '/home/ronny')
>>> subprocess.getoutput('pwd')
'/home/ronny'
>>> subprocess.getstatus('pwd')
Traceback (most recent call last):
File "", line 1, in
AttributeError: module 'subprocess' has no attribute 'getstatus'
以上执行shell命令的相关的模块和函数的功能均在 subprocess 模块中实现,并提供了更丰富的功能。
(1) call
执行命令,返回状态码(命令正常执行返回0,报错则返回1)
ret1=subprocess.call("ifconfig")
ret2=subprocess.call("ipconfig") #python3.5不是这样,依然会抛出异常导致无法对ret2赋值
print(ret1) #0
print(ret2) #1
ret = subprocess.call(["ls", "-l"], shell=False) #shell为False的时候命令必须分开写
ret = subprocess.call("ls -l", shell=True)
(2) check_call
执行命令,如果执行成功则返回状态码0,否则抛异常
subprocess.check_call(["ls", "-l"])
subprocess.check_call("exit 1", shell=True)
(3) check_output
执行命令,如果执行成功则返回执行结果,否则抛异仔侍常
subprocess.check_output(["echo", "Hello World!"])
subprocess.check_output("exit 1", shell=True)
(4) subprocess.Popen(...)
用于执行复杂的系统命令
参数
注释
args shell命令,可以是字符串或者序列类型(如:list,元组)
bufsize 指定缓冲。0 无缓冲,1 行缓冲,其他 缓冲区大小,负值 系统缓冲
stdin, stdout, stderr 分别表示程序的标准输入、输出、错误句柄
preexec_fn 只在Unix平台下有效,用于指定一个可念察吵执行对象(callable object),它将在子进程运行之前被调用
close_sfs 在windows平台下,如果close_fds被设置为True,则新创建的子进程将不会继承父进程的输入、输出、错误管道。所以不能将close_fds设置为True同时重定向子进程的标准输入、输出与错误(stdin, stdout, stderr)。
shell 同上
cwd 用于设置子进程的当前目录
env 用于指定子进程的环境变量。如果env = None,子进程的环境变量将从父进程中继承。
universal_newlines 不同系统的换行符不同,True -> 同意使用 \n
startupinfo 只在windows下有效,将被传递给底层的CreateProcess()函数,用于设置子进程的一些属性,如:主窗口的外观,进程的优先级等等
createionflags 同上
import subprocess
ret1 = subprocess.Popen(["mkdir","t1"])
ret2 = subprocess.Popen("mkdir t2", shell=True)
终端输入的命令分为两种:
-
输入即可得到输出,如:ifconfig
-
输入进行某环境,依赖再输入,如:python
- import subprocess
- obj = subprocess.Popen("mkdir t3", shell=True, cwd='/home/dev',) #在cwd目录下执行命令
- import subprocess
- obj = subprocess.Popen(["python"], stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE, universal_newlines=True)
- obj.stdin.write("print(1)\n")
- obj.stdin.write("print(2)")
- obj.stdin.close()
- cmd_out = obj.stdout.read()
- obj.stdout.close()
- cmd_error = obj.stderr.read()
- obj.stderr.close()
- print(cmd_out)
- print(cmd_error)
- import subprocess
- obj = subprocess.Popen(["python"], stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE, universal_newlines=True)
- obj.stdin.write("print(1)\n")
- obj.stdin.write("print(2)")
- out_error_list = obj.communicate()
- print(out_error_list)
- import subprocess
- obj = subprocess.Popen(["python"], stdin=subprocess.PIPE, stdout=subprocess.PIPE, stderr=subprocess.PIPE, universal_newlines=True)
- out_error_list = obj.communicate('print("hello")')print(out_error_list)
本文地址:https://gpu.xuandashi.com/71309.html,转载请说明来源于:渲大师
声明:本站部分内容来自网络,如无特殊说明或标注,均为本站原创发布。如若本站内容侵犯了原著者的合法权益,可联系我们进行处理。分享目的仅供大家学习与参考,不代表本站立场!