我想将subprocess.call()的STDOUT追加到现有文件中.我的代码覆盖了文件 –
log_file = open(log_file_path, 'r+')
cmd = r'echo "some info for the log file"'
subprocess.call(cmd, shell=True, stdout=log_file, stderr=STDOUT)
log_file.close()
我正在寻找相当于>>在subprocess.call()或subprocess.Popen()中.这让我疯狂地试图找到它..
更新:
到目前为止,我已经将代码更新为
import subprocess
log_file = open('test_log_file.log', 'a+')
cmd = r'echo "some info for the log file\n"'
subprocess.call(cmd, shell=True, stdout=log_file, stderr=subprocess.STDOUT)
log_file.close()
我在Windows中从命令行运行此代码 –
C:\users\aidan>test_subprocess.py
这会将文本添加到日志文件中.当我再次运行脚本时,没有添加任何新内容.它似乎仍然覆盖了文件..
解决方法:
改为使用’a’追加模式:
log_file = open(log_file_path, 'a+')
如果您仍然看到以前的内容被覆盖,也许Windows需要您明确地寻找到文件的末尾;以’r’或’w’打开并寻找文件的末尾:
import os
log_file = open(log_file_path, 'r+')
log_file.seek(0, os.SEEK_END)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。