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

Aid*_*wen 3 python windows subprocess stdout file

我想追加STDOUTsubprocess.call()现有文件.我的代码覆盖了文件 -

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()
Run Code Online (Sandbox Code Playgroud)

我正在寻找相当于>>in 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()
Run Code Online (Sandbox Code Playgroud)

我在Windows中从命令行运行此代码 -

C:\users\aidan>test_subprocess.py
Run Code Online (Sandbox Code Playgroud)

这会将文本添加到日志文件中.当我再次运行脚本时,没有添加任何新内容.它似乎仍然覆盖了文件..

Mar*_*ers 7

改为使用'a'追加模式:

log_file = open(log_file_path, 'a+')
Run Code Online (Sandbox Code Playgroud)

如果您仍然看到以前的内容被覆盖,也许Windows需要您明确地寻找到文​​件的末尾; 打开'r +'或'w'并寻找文件的末尾:

import os

log_file = open(log_file_path, 'r+')
log_file.seek(0, os.SEEK_END)
Run Code Online (Sandbox Code Playgroud)