日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

python stdout stderr 一起输出_Python在保留顺序的同时分别从子进程stdout和stderr读取...

發(fā)布時間:2025/3/21 python 34 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python stdout stderr 一起输出_Python在保留顺序的同时分别从子进程stdout和stderr读取... 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

小智..

6

寫入后,進程將數(shù)據(jù)寫入不同管道的順序?qū)G失。

您無法判斷在stderr之前是否已寫入stdout。

您可以嘗試在數(shù)據(jù)可用時以非阻塞方式同時從多個文件描述符中同時讀取數(shù)據(jù),但這只會最大程度地降低順序不正確的可能性。

該程序應(yīng)證明這一點:

#!/usr/bin/env python

# -*- coding: utf-8 -*-

import os

import select

import subprocess

testapps={

'slow': '''

import os

import time

os.write(1, 'aaa')

time.sleep(0.01)

os.write(2, 'bbb')

time.sleep(0.01)

os.write(1, 'ccc')

''',

'fast': '''

import os

os.write(1, 'aaa')

os.write(2, 'bbb')

os.write(1, 'ccc')

''',

'fast2': '''

import os

os.write(1, 'aaa')

os.write(2, 'bbbbbbbbbbbbbbb')

os.write(1, 'ccc')

'''

}

def readfds(fds, maxread):

while True:

fdsin, _, _ = select.select(fds,[],[])

for fd in fdsin:

s = os.read(fd, maxread)

if len(s) == 0:

fds.remove(fd)

continue

yield fd, s

if fds == []:

break

def readfromapp(app, rounds=10, maxread=1024):

f=open('testapp.py', 'w')

f.write(testapps[app])

f.close()

results={}

for i in range(0, rounds):

p = subprocess.Popen(['python', 'testapp.py'], stdout=subprocess.PIPE

, stderr=subprocess.PIPE)

data=''

for (fd, s) in readfds([p.stdout.fileno(), p.stderr.fileno()], maxread):

data = data + s

results[data] = results[data] + 1 if data in results else 1

print 'running %i rounds %s with maxread=%i' % (rounds, app, maxread)

results = sorted(results.items(), key=lambda (k,v): k, reverse=False)

for data, count in results:

print '%03i x %s' % (count, data)

print

print "=> if output is produced slowly this should work as whished"

print " and should return: aaabbbccc"

readfromapp('slow', rounds=100, maxread=1024)

print

print "=> now mostly aaacccbbb is returnd, not as it should be"

readfromapp('fast', rounds=100, maxread=1024)

print

print "=> you could try to read data one by one, and return"

print " e.g. a whole line only when LF is read"

print " (b's should be finished before c's)"

readfromapp('fast', rounds=100, maxread=1)

print

print "=> but even this won't work ..."

readfromapp('fast2', rounds=100, maxread=1)

并輸出如下內(nèi)容:

=> if output is produced slowly this should work as whished

and should return: aaabbbccc

running 100 rounds slow with maxread=1024

100 x aaabbbccc

=> now mostly aaacccbbb is returnd, not as it should be

running 100 rounds fast with maxread=1024

006 x aaabbbccc

094 x aaacccbbb

=> you could try to read data one by one, and return

e.g. a whole line only when LF is read

(b's should be finished before c's)

running 100 rounds fast with maxread=1

003 x aaabbbccc

003 x aababcbcc

094 x abababccc

=> but even this won't work ...

running 100 rounds fast2 with maxread=1

003 x aaabbbbbbbbbbbbbbbccc

001 x aaacbcbcbbbbbbbbbbbbb

008 x aababcbcbcbbbbbbbbbbb

088 x abababcbcbcbbbbbbbbbb

總結(jié)

以上是生活随笔為你收集整理的python stdout stderr 一起输出_Python在保留顺序的同时分别从子进程stdout和stderr读取...的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 一二三区在线播放 | 国产在线久 | 中文字幕一区二区三区人妻不卡 | juliaann精品艳妇hd | 99热99热| 亚洲视频在线观看免费视频 | 国产精彩视频在线观看 | 国产免费91视频 | 超碰精品在线 | 国产精品一区无码 | 一区二区三区在线观看av | 国产天天操 | 日日舔夜夜操 | 国产综合精品在线 | 在线观看中文字幕视频 | 日日摸天天添天天添破 | 在线观看亚洲成人 | 精品久久久999| 久久久男女 | 黑人精品无码一区二区三区 | 有色影院 | 91精品成人 | 色婷婷综合久久久久中文一区二区 | 黄色1级大片 | 青青视频免费观看 | 狠狠干av| 四季av国产一区二区三区 | 亚洲免费视频播放 | 欧美一区日韩一区 | 免费成人在线看 | 就是喜欢被他干 | 国产美女诱惑 | 国产精选中文字幕 | 国产精品久久久久久久久久久久久久久久 | 国产精品欧美性爱 | 丰满大乳少妇在线观看网站 | www.com色| 玖玖色资源 | 超碰520| 成人黄色免费网 | 爽天天天天天天天 | 国产激情一区二区三区视频免樱桃 | 日中文字幕 | 欧美一级黄视频 | 亚洲精品1234 | 女生的胸无遮挡 | www.奇米.com| 日韩在线视频网站 | 一区二区视频免费在线观看 | 爽爽影院在线免费观看 | 国产精品夜夜夜爽阿娇 | 绿帽在线 | 免费观看黄色一级视频 | 日本在线一本 | 欧美无人区码suv | 天堂网2014| 亚洲一区二区三区在线视频观看 | 青娱乐精品视频 | 悟空影视大全免费高清观看在线 | 97免费人妻无码视频 | 少妇被躁爽到高潮 | 波多野吉衣久久 | 欧美午夜激情影院 | 黄色小视频在线观看 | 成人aaa视频 | 中文字幕女同 | 国产99久久久久久免费看 | 免费禁漫天堂a3d | 成人小视频免费在线观看 | 日韩精品综合 | 美女伦理水蜜桃4 | 天天干天天谢 | 看久久| 打屁股外国网站 | 国产高清在线精品 | 清纯唯美第一页 | 少妇的激情 | 亚欧日韩av | 亚洲一区二区三区高清 | 亚洲精品高清视频在线观看 | 91日日| 国产精品免费一区二区 | 亚洲天堂av一区二区三区 | 免费91看片 | 欧美爱爱爱 | 国产精品视频一区二区三区在3 | 日韩欧美国产精品综合嫩v 国产小毛片 | 人人爱操 | 欧美成人不卡视频 | 校园春色综合 | 国产成人激情 | 调教亲女小嫩苞h文小说 | 36d大奶 | 久久精品www人人爽人人 | 欧美xxxx免费虐 | 欧美精品一区二区成人 | 欧美乱色 | 伊人久久99 | 五月天国产|