【发布时间】:2018-11-05 15:14:55
【问题描述】:
假设我有一个我正在迭代的文件字典。我正在对每个文件进行一些处理,然后将其写入报告(注意:不使用csv mod)。
file_list = ['f1', 'f2', 'f3', 'f4']
report = "C:/reports/report_%s"%(timestamp)
r = open(report, "w')
如果 f3 中发生的事情在脚本完成之前使脚本崩溃,会发生什么情况。我可以使用try-catch 来处理错误,但我不想只关闭报告。也许我希望脚本继续。脚本运行时可能出现电源故障。也许有多个try-catch 语句,我不想为每个错误关闭。本质上,我只想保存文件而不在列表的每次迭代中关闭它,这样如果发生崩溃,我仍然可以检索到该点之前写入报告的数据。我怎样才能做到这一点?我不能简单地做report.save(),对吧?我考虑过将flush() 与os.fsync() 一起使用,正如另一个question 中所解释的那样,但我不能100% 确定这适用于我的场景。关于如何在这里实现我的目标有什么建议吗?
try:
....do stuff...
report.write(<stuff_output> + "\n")
try:
....do more stuff....
report.write(<stuff_output> + "\n")
except:
continue
report.close()
except Exception as e:
pass
【问题讨论】:
标签: python-2.7 file file-writing saving-data