我正在创建一个例程,我将在Windows中将其设置为计划任务,以自动获取我们的数据库的副本,并将其发布到Web服务器,供客户下载。
我已经在子流程调用的参数中使用静态字符串使一切正常工作,该子流程调用使用7-zip创建自解压存档。但是,当我试图通过使用os.path.join和os.path.dirname来动态确定subprocess.call函数的参数值来使逻辑更加不可知时,事情就停止了。
我不知道出了什么问题,因为当我在cmd控制台中运行它,并提供静态字符串作为参数时,它工作得很好。此外,当我使用静态字符串时,它可以通过Python很好地工作。只有当我将变量和函数引入到参数中以尝试动态确定参数值时,才会提供错误代码或消息。
# Get the Database location
localGDB = os.path.join(os.path.dirname(__file__), r"Resources\MyDatabase.gdb")
# Wrap the local File Geodatabase into a self-extracting exe
print "Wrapping local database..."
try:
subprocess.Popen([str(os.path.join(os.path.dirname(__file__), r"Resources\7z\7-Zip64\7z.exe")),
"a",
"-sfx",
str(os.path.join(os.path.dirname(__file__), "MyDatabase.exe")),
str(localGDB)])
except Exception as e:
ctypes.windll.user32.MessageBoxA(0, "An error occured while wrapping the database." + e.message, "ERROR", 0 | 0x10)
sys.exit(1)发布于 2015-11-20 23:29:50
如果是在windows上,我建议运行subprocess.check_output()
发布于 2015-11-21 01:28:50
谢谢大家。在接受tdelaney的建议检查路径后,我发现7zip路径是不正确的。
https://stackoverflow.com/questions/33829996
复制相似问题