python中的lo函数_Loguru:优雅的Python程序日志

0c27ac960546

习惯了使用Python自带的logging模块记录日志,但是总觉得不够优雅。

Loguru解决了这个问题。guru是印度语中大师的意思,直译就是“日志大师”。

0c27ac960546

0c27ac960546

使用pip安装

pip install loguru

开箱即用

不同的日志等级,输出效果也不一样(等级由低到高是DEBUG、INFO、WARNING、ERROR、CRITICAL)

logger.debug("That's it, beautiful and simple logging!")

logger.info("That's it, beautiful and simple logging!")

logger.warning("That's it, beautiful and simple logging!")

logger.error("That's it, beautiful and simple logging!")

logger.critical("That's it, beautiful and simple logging!")

0c27ac960546

统一的add()函数

add()函数用于注册“沉量”sink,用于管理日志消息。

logger.add(sink='log.txt', format="{time} {level} {message}", filter="my_module", level="INFO")

将上面两个功能合起来,就能实现最基本的日志功能了。

from loguru import logger

logger.add(sink='log.log', format="{time} - {level} - {message}", level="INFO")

logger.info("That's it, beautiful and simple logging!")

可以用rotation、retention、compression进行日志窗口、更新、压缩管理。

logger.add("file_1.log", rotation="500 MB") # 日志文件的窗口大小是500M

logger.add("file_2.log", rotation="12:00") # 每天中午12点创建新日志文件

logger.add("file_3.log", rotation="1 week") # 自动更新旧文件

logger.add("file_X.log", retention="10 days") # 清理旧文件

logger.add("file_Y.log", compression="zip") # 压缩文件

loguru支持f-string:

logger.info("If you're using Python {}, prefer {feature} of course!", 3.6, feature="f-strings")

Loguru支持在主进程和线程中捕获异常,使用@logger.catch

from loguru import logger

logger.add(sink='log.log', format="{time} - {level} - {message}", level="INFO")

@logger.catch

def my_function(x, y, z):

return 1 / (x + y + z)

res = my_function(0,0,0)

print(res)

修改日志文字的颜色

logger.add(sys.stdout, colorize=True, format="{time}{message}")

使用enqueue,可以保证多线程安全、多进程安全

logger.add("somefile.log", enqueue=True)

详细的异常回溯

使用backtrace、diagnose

from loguru import logger

logger.add("output.log", backtrace=True, diagnose=True) # 设置为'False'可以保证生产中不泄露信息

def func(a, b):

return a / b

def nested(c):

try:

func(5, c)

except ZeroDivisionError:

logger.exception("What?!")

nested(0)

修改时间格式

logger.add("file.log", format="{time:YYYY-MM-DD at HH:mm:ss} | {level} | {message}")

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值