下面我们使用代码logging的代码来说明:

使用baseConfig()函数对 logging进行 简单的 配置:

  1. import logging;
  2. # 使用baseConfig()函数,可选参数有filename,filemode,format,datefmt,level,stream
  3. # 有filename是文件日志输出,filemode是'w'的话,文件会被覆盖之前生成的文件会被覆盖。datafmt参数用于格式化日期的输出
  4. logging.basicConfig(filename="config.log",filemode="w",format="%(asctime)s-%(name)s-%(levelname)s-%(message)s",level=logging.INFO);
  5. # 使用logging输出日志信息
  6. logging.debug("debug");
  7. logging.info("info");
  8. logging.warning("warning");
  9. logging.error("error");
  10. logging.critical("critiacl");

通过初始化logger,handler,formater来配置logging:

  1. import logging;
  2. # logging模块由logger,handler,filter,fomatter四个部分组成
  3. # 获取一个logger对象
  4. logger = logging.getLogger("haha");
  5. # 设置日志输出等级
  6. logger.setLevel(logging.DEBUG);
  7. # 创建一个文件的handler
  8. f_handler = logging.FileHandler("xxx.log");
  9. f_handler.setLevel(logging.INFO);
  10. # 创建一个控制台的handler
  11. c_handler = logging.StreamHandler();
  12. c_handler.setLevel(logging.WARNING);
  13. # 设置日志的输出格式
  14. fmt = logging.Formatter("%(asctime)s-%(name)s-%(levelname)s-%(message)s");
  15. # 给handler绑定一个fomatter类
  16. f_handler.setFormatter(fmt);
  17. c_handler.setFormatter(fmt);
  18. # 绑定一个handler
  19. logger.addHandler(f_handler);
  20. logger.addHandler(c_handler);
  21. # 使用logger输出日志信息
  22. logger.debug("debug");
  23. logger.info("info");
  24. logger.warning("warning");
  25. logger.error("error");
  26. logger.critical("critiacl");

使用配置文件实现logging的配置:

  1. import logging
  2. import logging.config
  3. # 使用配置文件配置logging
  4. logging.config.fileConfig("config.conf");
  5. logger = logging.getLogger("simpleExample");
  6. # 使用logger
  7. logger.debug("debug");
  8. logger.info("info");
  9. logger.warning("warning");
  10. logger.error("error");
  11. logger.critical("critiacl");

与之对应的配置文件内容如下:

  1. [loggers]
  2. keys=root,simpleExample
  3. [handlers]
  4. keys=consoleHandler,fileHandler
  5. [formatters]
  6. keys=simpleFormatter
  7. [logger_root]
  8. level=DEBUG
  9. handlers=consoleHandler
  10. [logger_simpleExample]
  11. level=DEBUG
  12. handlers=consoleHandler,fileHandler
  13. qualname=simpleExample
  14. propagate=0
  15. [handler_consoleHandler]
  16. class=StreamHandler
  17. level=DEBUG
  18. formatter=simpleFormatter
  19. args=(sys.stdout,)
  20. [handler_fileHandler]
  21. class=FileHandler
  22. level=WARNING
  23. formatter=simpleFormatter
  24. args=("file_config_log.log", "a")
  25. [formatter_simpleFormatter]
  26. format=%(asctime)s - %(name)s - %(levelname)s - %(message)s
  27. datefmt=

上面的配置文件中:由[loggers],[handlers],[formaters] 信息,keys对应实例化是他们的名称,多个用逗号隔开。然后再分别配置各个logger,handler,formaters。以logger为例,logger下有root和simpleExample两个logger,就要配置[logger_root]和[logger_simpleExample];类似的,handler和formater也是这样。

在[logger_name] 中的参数purlname ,是设置logging.getLoger(name)中的name值;propagete参数 :propagete=0,表示输出日志,但消息不传递;propagate=1是输出日志,同时消息往更高级别的地方传递。若上面配置文件参数progagate=1,simpleExample的更高级logger有root,输出的结果会是:

  1. 2012-08-06 23:07:18,483 - simpleExample - DEBUG - debug
  2. 2012-08-06 23:07:18,483 - simpleExample - DEBUG - debug
  3. 2012-08-06 23:07:18,483 - simpleExample - INFO - info
  4. 2012-08-06 23:07:18,483 - simpleExample - INFO - info
  5. 2012-08-06 23:07:18,483 - simpleExample - WARNING - warning
  6. 2012-08-06 23:07:18,483 - simpleExample - WARNING - warning
  7. 2012-08-06 23:07:18,483 - simpleExample - ERROR - error
  8. 2012-08-06 23:07:18,483 - simpleExample - ERROR - error
  9. 2012-08-06 23:07:18,483 - simpleExample - CRITICAL - critiacl
  10. 2012-08-06 23:07:18,483 - simpleExample - CRITICAL - critiacl

最后是 [hander_name] 配置下的args参数,其实就是你使用的handler类型的初始化函数的参数

logging 日志两种使用方法(转)的更多相关文章

  1. angular2系列教程(十)两种启动方法、两个路由服务、引用类型和单例模式的妙用

    今天我们要讲的是ng2的路由系统. 例子

  2. git两种合并方法 比较merge和rebase

    18:01 2015/11/18git两种合并方法 比较merge和rebase其实很简单,就是合并后每个commit提交的id记录的顺序而已注意:重要的是如果公司用了grrit,grrit不允许用m ...

  3. 两种Ajax方法

    两种Ajax方法 Ajax是一种用于快速创建动态网页的技术,他通过在后台与服务器进行少量的数据交换,可以实现网页的异步更新,不需要像传统网页那样重新加载页面也可以做到对网页的某部分作出更新,现在这项技 ...

  4. mysql in 的两种使用方法

    简述MySQL 的in 的两种使用方法: 他们各自是在 in keyword后跟一张表(记录集).以及在in后面加上字符串集. 先讲后面跟着一张表的. 首先阐述三张表的结构: s(sno,sname. ...

  5. C#中的两种debug方法

    这篇文章主要介绍了C#中的两种debug方法介绍,本文讲解了代码用 #if DEBUG 包裹.利用宏定义两种方法,需要的朋友可以参考下   第一种:需要把调试方法改成debug代码用 #if DEBU ...

  6. Service的两种启动方法

    刚才看到一个ppt,介绍service的两种启动方法以及两者之间的区别. startService 和 bindService startService被形容为我行我素,而bindService被形容 ...

  7. jQuery ajax调用后台aspx后台文件的两种常见方法(不是ashx)

    在asp.net webForm开发中,用Jquery ajax调用aspx页面的方法常用的有两种:下面我来简单介绍一下. [WebMethod] public static string SayHe ...

  8. android studio gradle 两种更新方法更新

    android studio gradle 两种更新方法更新 第一种.Android studio更新 第一步:在你所在项目文件夹下:你项目根目录gradlewrappergradle-wrapper ...

  9. iOS学习——UITableViewCell两种重用方法的区别

    今天在开发过程中用到了UITableView,在对cell进行设置的时候,我发现对UITableViewCell的重用设置的方法有如下两种,刚开始我也不太清楚这两种之间有什么区别.直到我在使用方法二进 ...

随机推荐

  1. Sublime Text 2创建可复用的代码片段

    对于前端工程师来讲,写一个html页面的基本结构是体力活,每次去拷贝一个也麻烦,sublime text 2 提供了一个很好的复用代码片段.下面介绍一下创建一个html5的代码片段的过程.在菜单上点击 ...

  2. mplab c30 注册方法

    http://blog.csdn.net/q553716434/article/details/7459036 关键文件是: C:\Program Files\Microchip\MPLAB C30\ ...

  3. 2017 Multi-University Training Contest - Team 4 phone call(树+lca+并查集)

    题解: (并查集处理往上跳的时候,一定要先让u,v往上跳到并查集的祖先,不然会wa掉) 代码如下: #include <iostream> #include <algorithm&g ...

  4. [洛谷P2147][SDOI2008]洞穴勘测

    题目大意:有$n$个洞穴,$m$条指令,指令有三种 $Connect\;u\;v$:在$u,v$之间连一条边 $Destroy\;u\;v$:切断$u,v$之间的边 $Query\;u\;v$:询问$ ...

  5. 理解NLP中的卷积神经网络(CNN)

    此篇文章是Denny Britz关于CNN在NLP中应用的理解,他本人也曾在Google Brain项目中参与多项关于NLP的项目. · 翻译不周到的地方请大家见谅. 阅读完本文大概需要7分钟左右的时 ...

  6. [Leetcode] Reorder list 重排链表

    Given a singly linked list L: L 0→L 1→…→L n-1→L n,reorder it to: L 0→L n →L 1→L n-1→L 2→L n-2→… You ...

  7. [bzoj1033] [ZJOI2008]杀蚂蚁 Big MoNI

    这个模拟就不用说了吧...... 注意事项(救命的):1.不能回原位 2.在可以打到target的塔打target的时候,其他打不到的继续打自己的(这是显然的事情只是当时已惘然) 3.如果游戏在某一秒 ...

  8. BZOJ2337: [HNOI2011]XOR和路径 期望概率dp 高斯

    这个题让我认识到我以往对于图上期望概率的认识是不完整的,我之前只知道正着退还硬生生的AC做过的所有图,那么现在让我来说一下逆退,一般来说对于概率性的东西都只是正推,因为有了他爸爸才有了他,而对于期望性 ...

  9. MyEclipse中代码提醒功能

    一:最近仔细研究了下spring mvc中的代码,自己在配置文件哪里来时出现问题,没有提醒,只好自己搜了下有关的信息.如下 window--->preferences---->java-- ...

  10. MySQL中大于等于小于等于的写法

    由于在mybatis框架的xml中<= , >=解析会出现问题,编译报错,所以需要转译 第一种写法: 原符号 < <= > >= & ' " 替换 ...