本篇文章给人人带来的内容是关于python中subprocess模块级要领的引见(附代码),有肯定的参考价值,有须要的朋侪能够参考一下,愿望对你有所协助。
subprocess.run()
运转并守候args参数指定的指令完成,返回CompletedProcess实例。
参数:(*popenargs, input=None, capture_output=False, timeout=None, check=False, **kwargs)。除input, capture_output, timeout, check,其他参数与Popen组织器参数一致。
capture_output:假如设置为True,示意重定向stdout和stderr到管道,且不能再通报stderr或stdout参数,不然抛出非常。
input:input参数将作为子历程的规范输入通报给Popen.communicate()要领,必需是string(须要指定encoding或errors参数,或许设置text为True)或byte范例。非None的input参数不能和stdin参数一同运用,不然将抛出非常,组织Popen实例的stdin参数将指定为subprocess.PIPE。
timeout:通报给Popen.communicate()要领。
check:假如设置为True,历程实行返回非0状况码将抛出CalledProcessError非常。
# 源码 def run(*popenargs, input=None, capture_output=False, timeout=None, check=False, **kwargs): if input is not None: if 'stdin' in kwargs: raise ValueError('stdin and input arguments may not both be used.') kwargs['stdin'] = PIPE if capture_output: if ('stdout' in kwargs) or ('stderr' in kwargs): raise ValueError('stdout and stderr arguments may not be used ' 'with capture_output.') kwargs['stdout'] = PIPE kwargs['stderr'] = PIPE with Popen(*popenargs, **kwargs) as process: try: stdout, stderr = process.communicate(input, timeout=timeout) except TimeoutExpired: process.kill() stdout, stderr = process.communicate() raise TimeoutExpired(process.args, timeout, output=stdout, stderr=stderr) except: # Including KeyboardInterrupt, communicate handled that. process.kill() # We don't call process.wait() as .__exit__ does that for us. raise retcode = process.poll() if check and retcode: raise CalledProcessError(retcode, process.args, output=stdout, stderr=stderr) return CompletedProcess(process.args, retcode, stdout, stderr)
python3.5版本前,call(), check_all(), checkoutput()三种要领构成了subprocess模块的高等API。
subprocess.call()
运转并守候args参数指定的指令完成,返回实行状况码(Popen实例的returncode属性)。
参数:(*popenargs, timeout=None, **kwargs)。与Popen组织器参数基础雷同,除timeout外的一切参数都将通报给Popen接口。
挪用call()函数不要运用stdout=PIPE或stderr=PIPE,由于假如子历程生成了充足的输出到管道填满OS管道缓冲区,子历程将因不能从管道读取数据而致使壅塞。
# 源码 def call(*popenargs, timeout=None, **kwargs): with Popen(*popenargs, **kwargs) as p: try: return p.wait(timeout=timeout) except: p.kill() p.wait() raise
subprocess.check_call()
运转并守候args参数指定的指令完成,返回0状况码或抛出CalledProcessError非常,该非常的cmd和returncode属性能够检察实行非常的指令和状况码。
参数:(*popenargs, **kwargs)。悉数参数通报给call()函数。
注意事项同call()
# 源码 def check_call(*popenargs, **kwargs): retcode = call(*popenargs, **kwargs) if retcode: cmd = kwargs.get("args") if cmd is None: cmd = popenargs[0] raise CalledProcessError(retcode, cmd) return 0
subprocess.check_output()
运转并守候args参数指定的指令完成,返回规范输出(CompletedProcess实例的stdout属性),范例默许是byte字节,字节编码能够取决于实行的指令,设置universal_newlines=True能够返回string范例的值。
假如实行状况码非0,将抛出CalledProcessError非常。
参数:(*popenargs, timeout=None, **kwargs)。悉数参数通报给run()函数,但不支撑显现地通报input=None继续父历程的规范输入文件句柄。
要在返回值中捕捉规范毛病,设置stderr=subprocess.STDOUT;也能够将规范毛病重定向到管道stderr=subprocess.PIPE,经由过程CalledProcessError非常的stderr属性接见。
# 源码 def check_output(*popenargs, timeout=None, **kwargs): if 'stdout' in kwargs: raise ValueError('stdout argument not allowed, it will be overridden.') if 'input' in kwargs and kwargs['input'] is None: # Explicitly passing input=None was previously equivalent to passing an # empty string. That is maintained here for backwards compatibility. kwargs['input'] = '' if kwargs.get('universal_newlines', False) else b'' return run(*popenargs, stdout=PIPE, timeout=timeout, check=True, **kwargs).stdout
subprocess模块还供应了python2.x版本中commands模块的相干函数。
subprocess.getstatusoutput(cmd)
实际上是挪用check_output()函数,在shell中实行string范例的cmd指令,返回(exitcode, output)情势的元组,output(包括stderr和stdout)是运用locale encoding解码的字符串,并删除了末端的换行符。
# 源码 try: data = check_output(cmd, shell=True, universal_newlines=True, stderr=STDOUT) exitcode = 0 except CalledProcessError as ex: data = ex.output exitcode = ex.returncode if data[-1:] == '\n': data = data[:-1] return exitcode, data
subprocess.getoutput(cmd)
与getstatusoutput()相似,但效果只返回output。
本篇文章到这里就已悉数完毕了,更多其他精彩内容能够关注ki4网的python视频教程栏目!
以上就是python中subprocess模块级要领的引见(附代码)的细致内容,更多请关注ki4网别的相干文章!