您的位置:首页 > 编程语言 > Python开发

python中的commands模块,执行出错:'{' 不是内部或外部命令,也不是可运行的程序 或批处理文件。

2015-01-14 10:50 1106 查看
最近发现了python的commands模块,查看了下源码,使用的popen封装的,形成三个函数getstatus(), getoutput(), getstatusoutput()

源码如下:

def getstatus(file):
"""Return output of "ls -ld <file>" in a string."""
import warnings
warnings.warn("commands.getstatus() is deprecated", DeprecationWarning, 2)
return getoutput('ls -ld' + mkarg(file))

# Get the output from a shell command into a string.
# The exit status is ignored; a trailing newline is stripped.
# Assume the command will work with '{ ... ; } 2>&1' around it..
#
def getoutput(cmd):
"""Return output (stdout or stderr) of executing cmd in a shell."""
return getstatusoutput(cmd)[1]

# Ditto but preserving the exit status.
# Returns a pair (sts, output)
#
def getstatusoutput(cmd):
"""Return (status, output) of executing cmd in a shell."""
import os
pipe = os.popen('{ ' + cmd + '; } 2>&1', 'r')
text = pipe.read()
sts = pipe.close()
if sts is None: sts = 0
if text[-1:] == '\n': text = text[:-1]
return sts, text


  通过查看以上源码,发现主要使用的是函数getstatusoutput()。

我调用这个函数的时候,每次的执行结果都是:'{' 不是内部或外部命令,也不是可运行的程序 或批处理文件。

怀疑是getstatusoutput()中的这句话pipe = os.popen('{ ' + cmd + '; } 2>&1', 'r')有问题。但是想想这是官网提供的模块,按说不会出现这种问题。

把pipe = os.popen('{ ' + cmd + '; } 2>&1', 'r'),修改为pipe = os.popen('{ ' + cmd + '; }2>&1', 'r'),就是把2>&1前的空格去掉,结果执行没有'{' 不是内部或外部命令,也不是可运行的程序 或批处理文件错误了,但是没有执行结果。

目前不知道怎么解决这个问题,可能是系统的问题吧。

别人使用相同的代码,执行结果正确。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐