subprocess: unexpected keyword argument capture_output

瘦欲@ 提交于 2021-02-07 04:40:11

问题


When executing subprocess.run() as given in the Python docs, I get a TypeError:

>>> import subprocess
>>> subprocess.run(["ls", "-l", "/dev/null"], capture_output=True)
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/lib/python3.6/subprocess.py", line 403, in run
    with Popen(*popenargs, **kwargs) as process:
TypeError: __init__() got an unexpected keyword argument 'capture_output'

I am running Python 3.6.6:

$ python3 --version
Python 3.6.6

回答1:


You inspected the wrong documentation, for python-3.6 this parameter does not exist, as can be found in the documentation (you select the version at the top left):

subprocess.run(args, *, stdin=None, input=None, stdout=None, stderr=None,
               shell=False, cwd=None, timeout=None, check=False, encoding=None,
               errors=None, env=None)

You can however easily "emulate" this by setting both stdout and stderr to PIPE:

from subprocess import PIPE

subprocess.run(["ls", "-l", "/dev/null"], stdout=PIPE, stderr=PIPE)

In fact, if we look at the source code of the python-3.7 version, where the feature was introduced, we see in the source code [GitHub]:

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



回答2:


The simplest method is to use the subprocess.check_output function:

import subprocess
subprocess.check_output(["ls", "-l", "/dev/null"])



回答3:


I ran into this error because I was calling subprocess.call (which is the old high level API) instead of subprocess.run.



来源:https://stackoverflow.com/questions/53209127/subprocess-unexpected-keyword-argument-capture-output

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!