python学习之9 日志记录logging

python学习之9 日志记录logging

logging库是python自带的记录运行日志的库。
日志的级别:
1. DEBUG:详细的信息,通常只出现在诊断问题上
2. INFO:确认一切按预期运行
2. WARNING:一个迹象表明,一些意想不到的事情发生了,或表明一些问题在不久的将来(例如。磁盘空间低”)。这个软件还能按预期工作。
4. ERROR:个更严重的问题,软件没能执行一些功能
5. CRITICAL:一个严重的错误,这表明程序本身可能无法继续运行

函数

import logging
这里只使用写入文本文件的。

测试源码

# coding = utf-8
####################################################
# coding by 刘云飞
####################################################
import logging
import os

# 获取当前目录
FILE = os.getcwd()
logging.basicConfig(filename=os.path.join(FILE, 'log.txt'),
                    level=logging.DEBUG,
                    format="%(asctime)s:%(filename)s[line:%(lineno)d] %(levelname)s %(message)s",
                    )
# 写入debug日志
logging.debug("hello i am debug")
# 写入info日志
logging.info("hello ,i am info")
# 写入warning日志
logging.warning("hello, warning") 

输出的文件内容为

2016-01-30 21:32:16,330:test_logging.py[line:15] DEBUG hello i am debug
2016-01-30 21:32:16,330:test_logging.py[line:17] INFO hello ,i am info
2016-01-30 21:32:16,330:test_logging.py[line:19] WARNING hello, warning

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python中的logging模块可以记录行号,您可以通过在loggers和handlers中设置相应的参数来实现。 在logger中,您可以使用`%(lineno)d`占位符来记录行号,示例代码如下: ``` import logging logger = logging.getLogger(__name__) logger.setLevel(logging.DEBUG) formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s - Line:%(lineno)d') console_handler = logging.StreamHandler() console_handler.setLevel(logging.DEBUG) console_handler.setFormatter(formatter) logger.addHandler(console_handler) logger.debug('This is a debug message') ``` 在上述示例中,`'%(asctime)s - %(name)s - %(levelname)s - %(message)s - Line:%(lineno)d'`是格式化字符串,其中`'%(lineno)d'`即为行号占位符。我们通过StreamHandler将日志输出到控制台,然后使用debug级别输出一条带有行号信息的日志。 如果您想将日志输出到文件并记录行号,可以使用FileHandler,示例代码如下: ``` import logging logger = logging.getLogger(__name__) logger.setLevel(logging.DEBUG) formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s - Line:%(lineno)d') file_handler = logging.FileHandler('log_file.log') file_handler.setLevel(logging.DEBUG) file_handler.setFormatter(formatter) logger.addHandler(file_handler) logger.debug('This is a debug message') ``` 在上述示例中,我们使用了FileHandler将日志输出到文件,并同样使用debug级别输出一条带有行号信息的日志

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值