最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • Python之logging模块相关介绍

    正文概述    2020-08-14   242

    Python之logging模块相关介绍

    python的logging模块

    python提供了一个日志处理的模块,那就是logging。

    导入logging模块使用以下命令:

    import logging

    logging模块的用法:

    1.简单的将日志打印到屏幕上

    import logging
    logging.debug("This is debug message")
    logging.info("This is info message")
    logging.warning("This is warning message")
    logging.error("This is error message")
    logging.critical("This is critical message")

    会在屏幕上显示出以下内容:

    WARNING:root:This is warning message
    ERROR:root:This is error message
    CRITICAL:root:This is critical message

    默认情况下python的logging模块将日志打印到了标准输出中,也就是屏幕上,且只显示了大于等于WARNING级别的日志.

    这说明默认的日志级别设置为WARNING(日志级别等级CRITICAL > ERROR > WARNING > INFO > DEBUG)

    默认直接输出的日志格式为日志级别:Logger名称:用户:输出消息。

    2.现在修改日志的默认输出级别为debug,重新设定输出时间的格式,

    import logging
    logging.basicConfig(level=logging.DEBUG,
                        format="%(asctime)s %(levelname)s %(message)s",
                        datefmt="%Y-%m-%d %H:%M:%S")
    logging.debug("This is debug message")
    logging.info("This is info message")
    logging.warning("This is warning message")
    logging.error("This is error message")
    logging.critical("This is critical message")

    会在屏幕上显示以下信息;

    2017-07-02 10:41:18 DEBUG This is debug message
    2017-07-02 10:41:18 INFO This is info message
    2017-07-02 10:41:18 WARNING This is warning message
    2017-07-02 10:41:18 ERROR This is error message
    2017-07-02 10:41:18 CRITICAL This is critical message

    相关推荐:《Python视频教程》

    3.现在想把程序产生的日志写入文件当中,可以这样设定:

    import logging
    logging.basicConfig(level=logging.DEBUG,
                        format="%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s",
                        datefmt="%Y-%m-%d %H:%M:%S",
                        filename="log.txt",
                        filemode="w")
    logging.debug("This is debug message")
    logging.info("This is info message")
    logging.warning("This is warning message")
    logging.error("This is error message")
    logging.critical("This is critical message")

    运行程序,会在脚本目录下生成一个名为log.txt的文件。

    log.txt文件的内容如下:

    2017-07-02 10:49:13 logging_modules.py[line:211] DEBUG This is debug message
    2017-07-02 10:49:13 logging_modules.py[line:212] INFO This is info message
    2017-07-02 10:49:13 logging_modules.py[line:213] WARNING This is warning message
    2017-07-02 10:49:13 logging_modules.py[line:214] ERROR This is error message
    2017-07-02 10:49:13 logging_modules.py[line:215] CRITICAL This is critical message

    在这里设定日志文件的输出使用的是basicConfig这个方法:

    logging.basicConfig函数各参数:
    filename: 指定输出日志的文件名
    filemode: 和file函数意义相同,指定日志文件的打开模式,写入模式用'w',追加模式使用'a'
    format: 指定输出的内容的格式,其中可以使用的参数有:
         %(levelno)s: 指定输出日志的级别的数值
         %(levelname)s: 指定输出日志的级别的名称
         %(pathname)s: 指定当前执行程序的路径,其实就是sys.argv[0]
         %(filename)s: 指定保存日志文件的名字
         %(funcName)s: 打印日志的当前函数
         %(lineno)d: 打印日志的当前行号
         %(asctime)s: 打印日志的时间
         %(thread)d: 打印线程ID
         %(threadName)s: 打印线程名称
         %(process)d: 打印进程ID
         %(message)s: 打印日志信息
    datefmt: 指定时间格式,同time.strftime()
    level: 设置日志级别,默认为logging.WARNING,这里设定为logging.DEBUG

    4.既想现在就看到输出的日志,又想把程序运行的日志保存在文件里,方便以后查看,可以这样设定:

    import logging
    logger=logging.getLogger()
    #创建一个file_handle变量,用于把日志写入到文件
    file_handle=logging.FileHandler("log1.txt")
    #创建一个stream_handle变量,用于输出日志到屏幕上
    stream_handle=logging.StreamHandler()
    #设定输出日志的级别为debug级别
    logger.setLevel(logging.DEBUG)
    #设定输出日志的格式
    fmt=logging.Formatter("%(asctime)s-%(levelname)s-%(message)s")
    #为写入文件的日志添加已设定的格式
    file_handle.setFormatter(fmt)
    #为输出到屏幕的日志添加已设定的格式 
    stream_handle.setFormatter(fmt)
    logger.addHandler(file_handle)
    logger.addHandler(stream_handle)
    #设定输出日志的信息
    logging.debug("This is debug message")
    logging.info("This is info message")
    logging.warning("This is warning message")
    logging.error("This is error message")
    logging.critical("This is critical message")

    运行程序后,会生成一个名为log1.txt的文件,文件的内容和屏幕上显示的内容都是:

    2017-07-02 11:04:53,622-DEBUG-This is debug message
    2017-07-02 11:04:53,623-INFO-This is info message
    2017-07-02 11:04:53,623-WARNING-This is warning message
    2017-07-02 11:04:53,623-ERROR-This is error message
    2017-07-02 11:04:53,624-CRITICAL-This is critical message

    在这里,还可以添加以下选项用来指定把要写入文件的日志设定为debug级别,而输出到屏幕上的日志还是warning级别

    fh.setLevel(logging.Debug)

    起源地下载网 » Python之logging模块相关介绍

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元