微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

python子进程覆盖用于stdout的文件 – 我需要它附加到文件(windows)

我想将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 举报,一经查实,本站将立刻删除。

相关推荐