网络编程
位置:首页>> 网络编程>> Python编程>> python subprocess pipe 实时输出日志的操作

python subprocess pipe 实时输出日志的操作

作者:ADChen  发布时间:2022-10-07 00:39:51 

标签:python,subprocess,pipe,日志

* test11.py


import time
print "1"
time.sleep(2)
print "1"
time.sleep(2)
print "1"
time.sleep(2)
print "1"

* test.py

import subprocess

p = subprocess.Popen("python test11.py", shell=True, stdout=subprocess.PIPE)

# None表示正在执行中

while p.poll() is None: <br>out = p.stdout.readline() <br>if out != "": <br>print out

补充知识:python 通过 subprocess.Popen执行命令,重定向实时输出

执行命令


import subprocess
import sys

# 常用编码
GBK = 'gbk'
UTF8 = 'utf-8'

# 解码方式,一般 py 文件执行为utf-8 ,cmd 命令为 gbk
current_encoding = GBK
popen = subprocess.Popen('ping www.baidu.com', shell = True,
            stdout = subprocess.PIPE,
            stderr = subprocess.PIPE,
            bufsize = 1)
out,err = popen.communicate()
print('std_out: ' + out)
print('std_err: ' + err)
print('returncode: ' + str(popen.returncode))

执行 .py文件


import subprocess
import sys

# 常用编码
GBK = 'gbk'
UTF8 = 'utf-8'

current_encoding = UTF8
popen = subprocess.Popen('python D:\code\test.py',
            stdout = subprocess.PIPE,
            stderr = subprocess.PIPE,
            bufsize = 1)
out,err = popen.communicate()
print('std_out: ' + out)
print('std_err: ' + err)
print('returncode: ' + str(popen.returncode))

来源:https://www.cnblogs.com/chenadong/p/10150269.html

0
投稿

猜你喜欢

手机版 网络编程 asp之家 www.aspxhome.com