首页 > 解决方案 > 如何评估python变量并将其作为参数传递给命令

问题描述

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

但我无法传递变量日志文件。执行此脚本后,我希望看到一个文件:例如 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)

标签: pythonpython-3.x

解决方案


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

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

不过,使用该subprocess模块会更安全,以避免任何 shell 问题。

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

推荐阅读