此代码在运行时失败:
import datetime
import subprocess
startdate = datetime.datetime(2010,4,9)
for i in range(1):
startdate += datetime.timedelta(days=1)
enddate = datetime.datetime(2010,4,10)
for i in range(1):
enddate += datetime.timedelta(days=1)
subprocess.call("sudo mam-list-usagerecords -s \"" + str(startdate) + "\" -e \"" + str(enddate) + " --format csv --full")
程序运行时出现以下错误:
File "QuestCommand.py", line 12, in <module>
subprocess.call("sudo mam-list-usagerecords -s \"" + str(startdate) + "\" -e \"" + str(enddate) + " --format csv --full")
File "/usr/lib64/python2.7/subprocess.py", line 524, in call
return Popen(*popenargs, **kwargs).wait()
File "/usr/lib64/python2.7/subprocess.py", line 711, in __init__
errread, errwrite)
File "/usr/lib64/python2.7/subprocess.py", line 1327, in _execute_child
raise child_exception
我已经用其他方式多次运行了此代码,并更改了引号和其他内容。我对系统调用和利用HPC分配数据库还很陌生。我被困住了,如果有人可以帮助我解决这个问题,那将非常有帮助。
谢谢!
答案 0 :(得分:1)
在可能的情况下,传递包含命令名称及其参数的列表。
subprocess.call(["sudo", "mam-list-usagerecords",
"-s", str(startdate),
"-e", str(enddate),
"--format", "csv",
"--full"])
这避免了甚至不需要知道shell如何处理命令行的情况。
答案 1 :(得分:0)
当我第一次开始使用某些子过程方法时,我遇到了一些相同的问题。
尝试像这样运行代码:
import datetime
import subprocess
import shlex
startdate = datetime.datetime(2010, 4, 9) + datetime.timedelta(days=1)
enddate = datetime.datetime(2010, 4, 10) + datetime.timedelta(days=1)
command = (
"sudo mam-list-usagerecords -s "
+ str(startdate)
+ "-e"
+ str(enddate)
+ " --format csv --full"
)
print(command)
print(type(command))
print(shlex.split(command))
subprocess.call(shlex.split(command))
输出:
sudo mam-list-usagerecords -s 2010-04-10 00:00:00-e2010-04-11 00:00:00 --format csv --full
类'str'
['sudo','mam-list-usagerecords','-s','2010-04-10','00:00:00-e2010-04-11','00:00:00' ,'-format','csv','-full']
(已删除命令输出。)
将kwarg shell
设置为默认值False
时,该命令可能必须是shlex.split所做的收集。
args应该是程序参数的序列,或者是单个字符串。默认情况下,如果args是序列,则要执行的程序是args中的第一项。如果args是字符串,则解释取决于平台,并在下面进行描述。有关默认行为的其他区别,请参见shell和可执行参数。除非另有说明,否则建议将args作为序列传递。
这个问题曾经使我迷惑不解,直到我在文档中找到它为止。