av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

python程序輸出無內容的解決方式

瀏覽:3日期:2022-07-30 15:29:48

問題緣由

某項目中使用python腳本方式將日志文件中的數據持續的轉換格式輸出到另一文件中以供其他日志分析應用使用。但是當后臺運行采取重定向方式輸出到某一文件時,發現并沒有內容輸出,命令如下:

python xxx.py > xxx.log &

測試發現,當前臺直接輸出到終端時正常,使用后臺運行重定向的方式輸出到文件中時無法輸出。

解決辦法

發現是在程序運行時,輸出有緩存,只有當程序運行結束或者緩沖區滿后才會輸出。因為程序是一致在運行的所以不可能等待程序結束在輸出。并且要求是有實時性的所以等緩沖區滿輸出的方式也不可取。

所以采用在python運行時加上-u參數,如:

python -u xxx.py > xxx.log &

-u參數的意義是不使用緩沖的方式輸入輸出

詳細如下:

Force stdin, stdout and stderr to be totally unbuffered. On systems where it matters, also put stdin, stdout and stderr in binary mode. Note that there is internal buffering in xreadlines(), readlines() and file-object iterators (“for line in sys.stdin”) which is not influenced by this option. To work around this, you will want to use “sys.stdin.readline()” inside a “while 1:” loop.

補充知識:python中運行代碼時沒有報錯但是也沒有輸出而且還有exit code 0的結束標志

如下所示:

f=open('passwd.txt',’r’)print (f.read(4))f.close()

這是想要執行的代碼

passwd.txt中的內容

ntp:x:38:38::/etc/ntp:/sbin/nologinapache:x:48:48:Apache:/var/www:/sbin/nologinsaslauth:x:498:76:Saslauthd user:/var/empty/saslauth:/sbin/nologinpostfix:x:89:89::/var/spool/postfix:/sbin/nologingdm:x:42:42::/var/lib/gdm:/sbin/nologinpulse:x:497:496:PulseAudio System Daemon:/var/run/pulse:/sbin/nologin

但是輸出的結果是

Process finished with exit code 0

后來排查發現原來是解釋器的問題

我之前使用的解釋器是pycharm提供的虛擬解釋器

#####如何查看解釋器

點file?>new projects

python程序輸出無內容的解決方式

如果選擇的是2就是使用了pycharm提供的虛擬解釋器,又因為passwd.txt文件不是在虛擬環境中的所以就沒有輸出。

點擊3然后選擇你已經下載好的解釋器即可。

以上這篇python程序輸出無內容的解決方式就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持好吧啦網。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 在线日韩欧美 | 亚洲精品乱码久久久久久 | 亚洲欧美视频在线观看 | 国产不卡在线观看 | www.第四色 | 日韩精品视频一区二区三区 | 青青在线视频 | 亚洲黄色一级 | 欧美日韩黄色片 | 亚洲福利网 | 天天操天天操 | 亚洲免费福利视频 | 欧美中文字幕在线 | 日韩欧美精品一区二区 | 日韩一二三| 91在线视频播放 | www.成人 | 天天爱天天色 | 亚洲欧洲视频 | 久久日韩精品 | 日韩色在线| 黄色av免费看 | 国产黄色在线观看 | 精品久久视频 | 在线免费观看av网站 | 日韩免费在线观看视频 | 免费毛片在线 | 国产日本在线观看 | 中文字幕无人区二 | 在线婷婷 | 日韩在线视频一区二区三区 | 99久久久国产精品 | 日韩不卡在线观看 | 中文字幕黄色片 | 狠狠干婷婷 | 伊人激情网 | 天天做天天爽 | 九九视频免费观看 | 日韩一区二区三免费高清在线观看 | 色综合久久久久 | 自拍偷拍av |