Python subprocess.call用Linux源命令提高Oserror



在python2.7中,我们可以使用子过程软件包执行外部Linux命令。

import subprocess   
subprocess.call(["ls", "-l"]) // or  
subprocess.call("ls -l".split())

两个都起作用。我在当前工作目录中有一个文件test.sh,其中仅包含

date

所以我尝试了

>>> subprocess.call("pwd".split())
/home/ckim
0
>>> subprocess.call("cat test.sh".split())
date
0
>>> subprocess.call("source test.sh".split())
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/usr/lib/python2.7/subprocess.py", line 523, in call
    return Popen(*popenargs, **kwargs).wait()
  File "/usr/lib/python2.7/subprocess.py", line 711, in __init__
    errread, errwrite)
  File "/usr/lib/python2.7/subprocess.py", line 1343, in _execute_child
    raise child_exception
OSError: [Errno 2] No such file or directory

怎么了?
add(anders):这个问题和答案有足够的信息(但是我在这里留下我的问题..)调用" source"。命令来自subprocess.popen

source是一个shell indentin命令。Python的子过程模块提供了新的过程,不运行适当的Bourne Shell(或ZSH或KSH或KSH或等)。您无法访问subprocess.call

要确定是否可以使用subprocess模块运行特定命令,您可能需要使用which来获取有关您需要使用的命令的信息:

user@machine: ~
$ which source                                                                                                                                  [7:41:38]
source: shell built-in command
user@machine: ~
$ which cat                                                                                                                                     [7:41:42]
/bin/cat
user@machine: ~
$ which ls                                                                                                                                      [7:41:47]
ls: aliased to ls --color=tty

最新更新