python函数阻塞 函数阻塞怎么实现的

python os.system、os.popen、subprocess.Popen的区别

1、使用os.system("cmd")

成都创新互联是一家集网站建设,永顺企业网站建设,永顺品牌网站建设,网站定制,永顺网站建设报价,网络营销,网络优化,永顺网站推广为一体的创新建站企业,帮助传统企业提升企业形象加强企业竞争力。可充分满足这一群体相比中小企业更为丰富、高端、多元的互联网需求。同时我们时刻保持专业、时尚、前沿,时刻以成就客户成长自我,坚持不断学习、思考、沉淀、净化自己,让我们为更多的企业打造出实用型网站。

这是最简单的一种方法,其执行过程中会输出显示cmd命令执行的信息。

例如:print os.system("mkdir test") 输出:0

可以看到结果打印出0,表示命令执行成功;否则表示失败(再次执行该命令,输出:子目录或文件 test 已经存在。1)。

2、使用os.popen("cmd")

通过os.popen()返回的是 file read 的对象,对其进行读取read()操作可以看到执行的输出

例如:print os.popen("adb shell ls /sdcard/ | findstr aa.png").read() 输出:aa.png(若aa.png存在,否则输出为空)

3、subprocess.Popen("cmd")

subprocess模块被推荐用来替换一些老的模块和函数,如:os.system、os.spawn*、os.popen*等

subprocess模块目的是 启动一个新的进程并与之通信 ,最常用是定义类Popen,使用Popen可以创建进程,并与进程进行复杂的交互。其函数原型为:

classsubprocess.Popen(args, bufsize=0, executable=None, stdin=None, stdout=None, stderr=None, preexec_fn=None, close_fds=False, shell=False, cwd=None, env=None, universal_newlines=False, startupinfo=None, creationflags=0)

Popen非常强大,支持多种参数和模式,通过其构造函数可以看到支持很多参数。但Popen函数存在缺陷在于, 它是一个阻塞的方法 ,如果运行cmd命令时产生内容非常多,函数就容易阻塞。另一点, Popen方法也不会打印出cmd的执行信息 。

以下罗列常用到的参数:

args :这个参数必须是 字符串 或者是一个由 字符串成员的列表 。其中如果是一个字符串列表的话,那第一个成员为要运行的程序的路径以及程序名称;从第二个成员开始到最后一个成员为运行这个程序需要输入的参数。这与popen中是一样的。

bufsize: 一般使用比较少,略过。

executable: 指定要运行的程序,这个一般很少用到,因为要指定运行的程序在args中已经指定了。 stdin,stdout ,stderr: 分别代表程序的标准输入、标准输出、标准错误处理。可以选择的值有 PIPE , 已经存在的打开的文件对象 和 NONE 。若stdout是文件对象的话,要确保文件对象是处于打开状态。

shell:shell参数根据要执行的命令情况来定,如果将参数shell设为True,executable将指定程序使用的shell。在windows平台下,默认的shell由COMSPEC环境变量来指定。

python 中os.system和commands.getoutput的区别

1. 使用os.system("cmd")

这是最简单的一种方法,特点是执行的时候程序会打出cmd在linux上执行的信息。使用前需要import os。

[python]

os.system("ls")

2. 使用Popen模块产生新的process

现在大部分人都喜欢使用Popen。Popen方法不会打印出cmd在linux上执

行的信息。的确,Popen非常强大,支持多种参数和模式。使用前需要from subprocess import Popen,

PIPE。但是Popen函数有一个缺陷,就是它是一个阻塞的方法。如果运行cmd时产生的内容非常多,函数非常容易阻塞住。解决办法是不使用

wait()方法,但是也不能获得执行的返回值了。

Popen原型是:

[python]

subprocess.Popen(args, bufsize=0, executable=None, stdin=None, stdout=None, stderr=None, preexec_fn=None, close_fds=False, shell=False, cwd=None, env=None, universal_newlines=False, startupinfo=None, creationflags=0)

参数bufsize:指定缓冲。我到现在还不清楚这个参数的具体含义,望各个大牛指点。

参数executable用于指定可执行程序。一般情况下我们通过args参数来设置所要运行的程序。如果将参数shell设为 True,executable将指定程序使用的shell。在windows平台下,默认的shell由COMSPEC环境变量来指定。

参数stdin, stdout, stderr分别表示程序的标准输入、输出、错误句柄。他们可以是PIPE,文件描述符或文件对象,也可以设置为None,表示从父进程继承。

参数preexec_fn只在Unix平台下有效,用于指定一个可执行对象(callable object),它将在子进程运行之前被调用。

参数Close_sfs:在windows平台

下,如果close_fds被设置为True,则新创建的子进程将不会继承父进程的输入、输出、错误管

道。我们不能将close_fds设置为True同时重定向子进程的标准输入、输出与错误(stdin, stdout, stderr)。

如果参数shell设为true,程序将通过shell来执行。

参数cwd用于设置子进程的当前目录。

参数env是字典类型,用于指定子进程的环境变量。如果env = None,子进程的环境变量将从父进程中继承。

参数Universal_newlines:不同操作系统下,文本的换行符是不一样的。如:windows下用’/r/n’表示换,而Linux下用 ‘/n’。如果将此参数设置为True,Python统一把这些换行符当作’/n’来处理。

参数startupinfo与createionflags只在windows下用效,它们将被传递给底层的CreateProcess()函数,用 于设置子进程的一些属性,如:主窗口的外观,进程的优先级等等。

subprocess.PIPE

在创建Popen对象时,subprocess.PIPE可以初始化stdin, stdout或stderr参数,表示与子进程通信的标准流。

subprocess.STDOUT

创建Popen对象时,用于初始化stderr参数,表示将错误通过标准输出流输出。

Popen的方法:

Popen.poll()

用于检查子进程是否已经结束。设置并返回returncode属性。

Popen.wait()

等待子进程结束。设置并返回returncode属性。

Popen.communicate(input=None)

与子进程进行交互。向stdin发送数据,或从stdout和stderr中读取数据。可选参数input指定发送到子进程的参数。

Communicate()返回一个元组:(stdoutdata,

stderrdata)。注意:如果希望通过进程的stdin向其发送数据,在创建Popen对象的时候,参数stdin必须被设置为PIPE。同样,如

果希望从stdout和stderr获取数据,必须将stdout和stderr设置为PIPE。

Popen.send_signal(signal)

向子进程发送信号。

Popen.terminate()

停止(stop)子进程。在windows平台下,该方法将调用Windows API TerminateProcess()来结束子进程。

Popen.kill()

杀死子进程。

Popen.stdin

如果在创建Popen对象是,参数stdin被设置为PIPE,Popen.stdin将返回一个文件对象用于策子进程发送指令。否则返回None。

Popen.stdout

如果在创建Popen对象是,参数stdout被设置为PIPE,Popen.stdout将返回一个文件对象用于策子进程发送指令。否则返回 None。

Popen.stderr

如果在创建Popen对象是,参数stdout被设置为PIPE,Popen.stdout将返回一个文件对象用于策子进程发送指令。否则返回 None。

Popen.pid

获取子进程的进程ID。

Popen.returncode

获取进程的返回值。如果进程还没有结束,返回None。

例如:

[python]

p = Popen("cp -rf a/* b/", shell=True, stdout=PIPE, stderr=PIPE)

p.wait()

if p.returncode != 0:

print "Error."

return -1

3. 使用commands.getstatusoutput方法

这个方法也不会打印出cmd在linux上执行的信息。这个方法唯一的优点是,它不是一个阻塞的方法。即没有Popen函数阻塞的问题。使用前需要import commands。

例如:

[python]

status, output = commands.getstatusoutput("ls")

还有只获得output和status的方法:

[python]

commands.getoutput("ls")

commands.getstatus("ls")

python中join如果加在列表下面,是对列表的阻塞还是列表里面子线程的阻塞

t.join会等待这个t退出后才继续运行,因为t.join是运行在主线程中,因此会阻塞主线程,即阻塞整个for循环。只有t.join的线程退出后才会继续执行下一个for循环。在主线程阻塞期间,子线程不会被阻塞,依然会继续运行。

python 怎么启动一个外部命令程序,并且不阻塞当前进程

如何启动一个外部命令程序, 并且不阻塞当前进程 在python中如何运行外部命令,并且调用后立即返回,不阻塞当前的进程。 调用 os.system函数时, python程序会被阻塞住, 直到外部命令结束。 比如我通过os.system('notepad'),运行记事本,除非我关闭记事本,不然python程序会一直阻塞, 有哪些方法能够不阻塞的运行外面命令吗?

python

------解决方案-------------------- subprocess.Popen os.startfile import os os.system(r'"D:\Program Files\Foxit Software\Foxit reader.exe" abc.pdf') 偶想""是不可缺少的,因为路径中有空格,否则极容易出错;对-参数不了解,不发表意见 使用os.system会有几个问题: 1、os.system会阻塞程序继续运行(如果是图形界面,还会把图形界面搞的没反应),当然如果需要阻塞,自然不是问题。 2、os.system会打开一个命令行窗口,这是比较讨厌的;除非你确实需要显示这个命令行窗口或者本来就是命令行里运行的。 所以还是建议使用 os.popen,基本语法是一样的 import os os.popen(r'"D:\Program Files\Foxit Software\Foxit reader.exe" abc.pdf') 这样不会出现命令行窗口,不会阻塞程序运行 如果需要阻塞程序运行,可以这样写: os.popen(r'"D:\Program Files\Foxit Software\Foxit reader.exe" abc.pdf').read()


当前标题:python函数阻塞 函数阻塞怎么实现的
分享链接:http://myzitong.com/article/hjcddo.html