Aid*_*wen 3 python windows subprocess stdout file
我想追加STDOUT的subprocess.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)
这会将文本添加到日志文件中.当我再次运行脚本时,没有添加任何新内容.它似乎仍然覆盖了文件..
改为使用'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)