如何计算python变量并将其作为参数传递给命令

时间:2019-05-28 13:27:27

标签: python python-3.x

在下面的python脚本中,我试图将当前日期和时间戳记转换为名为logfile的python变量,该变量作为参数传递给使用os.system(...)执行的Windows命令的输出重定向。

但是我无法传递变量日志文件。执行完此脚本后,我希望看到一个文件: log_28052019_133838.txt,其名称在执行时具有日期和时间戳记,并且具有dir / od命令的输出,但存储在文件日志文件中,告诉我变量名logfile的python表达式在传递前未得到求值作为输出重定向文件名。

有人可以指出我,我想念什么,以及实现我想要做的正确方法。

#!/bin/python

import os
import time

fstr = time.strftime("%d%b%Y_%H%M%S")
logfile = "log_"+fstr+".txt"
rcmd = 'dir /OD >logfile '

os.system(rcmd)

1 个答案:

答案 0 :(得分:3)

似乎logfile的值将允许您使用字符串格式来定义命令(尽管此命令很脆弱,在实践中不应使用):

logfile = time.strftime("log_%d%b%Y_%H%M%S.txt")
rcmd = 'dir /OD > {}'.format(logfile)
os.system(rcmd)

但是,使用subprocess模块会更安全,以避免出现任何外壳问题。

logfile = time.strftime("log_%d%b%Y_%H%M%S.txt")
with open(logfile, "w") as fh:
    subprocess.run(['dir', '/OD'], stdout=fh)