Python-写了1行日志,业务处理完毕为啥没有输出日志
off999 2024-10-30 03:03 43 浏览 0 评论
1. 前言
你有没有试过Python脚本输出日志的时候,看到日志文件没有及时输出日志。为什么会这样,今天跟大家分享下。
2.实际测试
以下例子是在Python-3.7.4环境下操作,请注意。
例子1:
确保当前环境变量PYTHONUNBUFFERED为空
$ export PYTHONUNBUFFERED=""新建一个testoutput.py
#!/usr/bin/python
# coding=utf-8
import sys
sys.stdout.write("stdout1 ")
sys.stderr.write("stderr1 ")
sys.stdout.write("stdout2 ")
sys.stderr.write("stderr2 ")执行结果:
$ python3 testoutput.py
stderr1 stderr2 stdout1 stdout2可以看到标准错误stderr是直接输出,无缓冲。
而标准输出stdout意思是行缓冲,而这里没有换行,等到缓存区满了之后,再输出。
例子2:
确保当前环境变量PYTHONUNBUFFERED为空
$ export PYTHONUNBUFFERED=""新建testoutput2.py
#!/usr/bin/python
# coding=utf-8
import sys
sys.stdout.write("stdout1\n")
sys.stderr.write("stderr1\n")
sys.stdout.write("stdout2\n")
sys.stderr.write("stderr2\n")执行结果:
$ python3 testoutput2.py
stdout1
stderr1
stdout2
stderr2跟例子2的区别仅仅是多加了个换行"\n",标准输出stdout就会及时输出。
例子 3:
确保当前环境变量PYTHONUNBUFFERED为空
$ export PYTHONUNBUFFERED=""新建一个third.py 文件
#!/usr/bin/python
# coding=utf-8
import subprocess
print('第1行输出')
subprocess.run("echo 第2行输出", shell=True, check=True)
print('第3行输出')结果:
$ python3 third.py
第1行输出
第2行输出
第3行输出而当我们进行重定向的时候会怎样呢?
$ python3 third.py > result.txt
-bash-4.1$ cat result.txt
第2行输出
第1行输出
第3行输出在这里可以看出print不是及时输出的,如果重定向文件,标准输出stdout和标准错误stderr进行缓存,等缓存区满了以后,再整体输出。
3.怎么及时输出呢?
- 设置环境变量 export PYTHONUNBUFFERED=1,可以加到用户环境变量中去。
- 执行python脚本的时候加上参数-u
4.啥时候需要缓存呢?
主要是为了降低io操作,比如写大文件,就可以进行缓存。
方法如下:
- 设置环境变量为空
export PYTHONUNBUFFERED=- 执行python脚本的时候不要加上参数-u
5.补充下-u参数说明:
对于3.7以上版本: 标准输出stdout和标准错误stderr全部采用unbuffered(无缓存)。
Changed in version 3.7: The text layer of the stdout and stderr streams now is un6.结束语
学会了吗?真棒。
喜欢本文的童鞋,可以关注我+收藏。
相关推荐
- 快吧游戏官网(快吧游戏中心)
-
1.快吧游戏可以通过官方网站或应用商店进行下载。2.官方网站提供了游戏的下载链接,也可以通过扫描二维码进行下载。快吧游戏是一款手机游戏,可以在应用商店中下载安装。以下是在iOS和Android系统...
- 最开放的浏览器下载(最开放的浏览器下载软件)
-
可以直接在浏览器设置内打开下载目录进行查看,步骤如下:所需材料:华为6X、华为浏览器示例。一、因为所有浏览器的设置基本一至,这里以华为浏览器为例,首先点击打开华为浏览器。二、打开浏览器后,点击右下角的...
- 万年历2025最新版(万年历2025最新版属相)
-
2024年正月初十对应的阳历出生日期是2024年2月1日。如果按照周岁来计算,他们属龙。辰龙(甲辰年):在中国传统文化中,龙象征着权力、尊贵和神圣。
- 163邮箱登录网页版(163邮箱登录网页版官网)
-
http://mail.163.com步骤一:输入邮箱官网网址http://mail.163.com/打开163邮箱登录入口界面。步骤二:输入已有的邮箱账号、密码,点击登录即可。步骤三:如果没有邮箱账...
- 青骄第二课堂学生登录入口(青骄第二课堂,登录入口)
-
青骄第二课堂学生账号注册是不需要学生注册的,是经过每个学校的老师就是班主任注册之后,学生才能登录首先我们要打开自己的微信,点击打开微信右上方的加号点击添加好友,点击公众号,搜索青椒第二课堂点...
- 视频剪辑器(视频剪辑器在线使用)
-
推荐4款常用的视频剪辑软件吧:大众级别的:剪大师、会声会影专业级别的:AdobePremiere、EDIUS先介绍大众级别的吧:一:剪大师?自动关键帧动画技术,多轨逐帧精确剪辑,制作精彩动画影片?...
- y2002电音(y2002电音app下载)
-
http://music.163.com/?t=1434936352062#/search/m/?s=Bear%20Grillz&type=1
- 刷机大师官网(如何自己刷机)
-
刷机工具除了爱思助手,还有一件刷机大师等第三方刷机工具。助手作为国内的一个第三方刷机工具,除了这个刷机工具之外,还有其他的辅助工具也能进行刷机,例如线刷大师或者线刷宝。以及一键刷机大师等第其他第三方...
- 4399以前的老游戏全部(4399以前的老游戏全部双人游戏)
-
现在都是玩另外的游戏的OL这款游戏的玩法多样,技能连招华丽,并且很实用,让我们的每一刀都那么使用,CAPCOM的游戏打击感总是那么爽落,OL也支持手柄模式,CAPCOM的手柄独特的打击震动,让...
- 斗地主游戏玩法(斗地主玩法百度经验)
-
该游戏由三人个玩一副牌,地主是一方,其余两家为另一方,双方对战,先出完的一方胜。出牌规则类似“争上游”。三人斗地主使用一副54张的扑克牌,包括两张怪(王),即大怪和小怪。牌面从大到小依次是:大怪、小怪...
欢迎 你 发表评论:
- 一周热门
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
