python stdout stderr 一起输出_Python捕获stdout/stderr并在看到outpu的同时记录到文件

所以我有一个python脚本,它试图自动化整个构建过程。因此,它不仅调用python文件,还调用shell脚本、maven等,所以我需要的是一个方法/过程/库,将stdout和stderr的输出捕获到日志文件,同时仍将其打印到控制台,即使打印到控制台的不是python脚本。在

我们在一台linux机器上工作,所以在手动操作时,我们先执行script,然后执行所有命令,然后执行exit。但是当试图用python脚本包装它时,似乎脚本接受shell的命令,并且在我先exit之前不允许我运行其余的命令。在

为了验证概念,这里有一个bash脚本,它每半秒打印一个数字,最多10个。在

print_nums.bash#!/bin/bash

for i in {1..10}

do

echo "$i"

sleep 0.5

done

这就是我想做的。在

test_script.py

^{pr2}$

我还研究了日志模块,但似乎只容易地将python打印捕获到日志中。我可能搞错了,如果有一个简单的方法,我肯定愿意改变方法论。但本质上,我希望能够在python中有效地说,从这里开始,我想记录控制台输出,这里我想以编程方式结束日志记录。在

您可以想象一个构建命令和初始测试可能需要很长的时间,比如15-20分钟,如果您只执行一个

some_command.bash > logfile.txt。在

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值