通常,在商用軟件中均會有完整的日志機制,之前使用C語言實現過一個[《簡單的分級別寫日志程序》](http://blog.csdn.net/dyx1024/article/details/4720484),具有以下功能和不足:
~~~
/************************************/
* 摘 要:此文件實現了普通WINDOWS程序中的日志功能
* 主要有以下特點:
* 1. 根據日期創建日志文件目錄,每天的日志分別存放在不同的日志目錄中;
* 2. 日志內容分三種類型,根據不同需要,寫不同的日志類型的日志文件,
* 方便通過日志定位、分析問題;
* 3. 函數經過比較好的封裝,便于復用;
* 待改進點:
* 1. 為了方便,日志內容打印時使用了time函數,其精確度較低;
* 2. 可將這些函數封裝為一個日志類,或者動態庫,使其更通用;
* 3. 沒有考慮跨平臺情景,目前只使用于WINDOWS下
* 4. 日志文件內容還可進一步改進,比如打印出當前文件名與行號,使用日志功能
* 更加實用;
*
* 當前版本:1.0
* 作 者:duanyongxing
* 完成日期:2009年10月11日
/************************************/
~~~
在Python中,上面以實現的和已經實現的,均可以使用logging模塊迅速搞定,且僅僅只需要一個配置文件,兩行代碼,實現過程如下(僅以輸出的磁盤文件為例,命令輸出只需要修改配置文件即可,具體可查API手冊):
1. 定義配置文件logging.conf:
~~~
[loggers]
keys=root,applog
[handlers]
keys=rotateFileHandler
[formatters]
keys=applog_format
[formatter_applog_format]
format=[%(asctime)s - %(name)s]%(levelname)s: %(message)s - %(filename)s:%(lineno)d
[logger_root]
level=NOTSET
handlers=rotateFileHandler
[logger_applog]
level=NOTSET
handlers=rotateFileHandler
qualname=simple_example
[handler_rotateFileHandler]
class=handlers.RotatingFileHandler
level=NOTSET
formatter=applog_format
args=('log_1.log', 'a', 10000, 9)
~~~
注意前三個[ ]中的keys,這個在后面各[ ]中定義定義,section的取名格式如looger_自定義名稱, handler_自定義名稱,我偷懶直接使用了標準名稱,其他一樣,最后一個要注意的就是format,即日志文件中內容的格式,具體見后面附一。level參數是日志級別,可擴展,如果使用python自己的,有以下四個級別:
~~~
Level Numeric value
CRITICAL 50
ERROR 40
WARNING 30
INFO 20
DEBUG 10
NOTSET 0
~~~
例如配置文件中level定義為WARN,則INFO, DEBUG,NOTSET三個級別的日志點則不會輸出,很方便的做到了日志級別控制。
args定義了日志方件名,寫方式,最大大小,保存最多個數等屬性。
2.編碼,測試
~~~
#!/usr/bin/env python
# -*- coding: utf-8 -*-
import logging
import logging.config
#日志初始化
LOG_FILENAME = 'logging.conf'
logging.config.fileConfig(LOG_FILENAME)
logger = logging.getLogger("simple_log_example")
#測試代碼
logger.debug("debug message")
logger.info("info message")
logger.warn("warn message")
logger.error("error message")
logger.critical("critical message")
~~~
運行后,查看日志文件,內容如下:
~~~
[2012-02-11 14:47:05,483 - simple_log_example]DEBUG: debug message - test_log.py:48
[2012-02-11 14:47:05,483 - simple_log_example]INFO: info message - test_log.py:49
[2012-02-11 14:47:05,483 - simple_log_example]WARNING: warn message - test_log.py:50
[2012-02-11 14:47:05,483 - simple_log_example]ERROR: error message - test_log.py:51
[2012-02-11 14:47:05,483 - simple_log_example]CRITICAL: critical message - test_log.py:52
~~~
如將日志級別設置為WARN,再次運行,查看日志:
~~~
[2012-02-11 14:54:20,046 - simple_log_example]WARNING: warn message - test_log.py:50
[2012-02-11 14:54:20,092 - simple_log_example]ERROR: error message - test_log.py:51
[2012-02-11 14:54:20,092 - simple_log_example]CRITICAL: critical message - test_log.py:52
~~~
附一:format參數格式說明:
~~~
Format Description
%(name)s Name of the logger (logging channel).
%(levelno)s Numeric logging level for the message (DEBUG, INFO, WARNING, ERROR, CRITICAL).
%(levelname)s Text logging level for the message ('DEBUG', 'INFO', 'WARNING', 'ERROR', 'CRITICAL').
%(pathname)s Full pathname of the source file where the logging call was issued (if available).
%(filename)s Filename portion of pathname.
%(module)s Module (name portion of filename).
%(funcName)s Name of function containing the logging call.
%(lineno)d Source line number where the logging call was issued (if available).
%(created)f Time when the LogRecord was created (as returned by time.time()).
%(relativeCreated)d Time in milliseconds when the LogRecord was created, relative to the time the logging module was loaded.
%(asctime)s Human-readable time when the LogRecord was created. By default this is of the form “2003-07-08 16:49:45,896” (the numbers after the comma are millisecond portion of the time).
%(msecs)d Millisecond portion of the time when the LogRecord was created.
%(thread)d Thread ID (if available).
%(threadName)s Thread name (if available).
%(process)d Process ID (if available).
%(message)s The logged message, computed as msg % args.
~~~
- 前言
- Python:實現文件歸檔
- Pyhon:按行輸出文件內容
- Python:讀文件和寫文件
- Python:實現一個小算法
- Python:通過命令行發送新浪微博
- Python:通過攝像頭實現的監控功能
- Python:通過攝像頭抓取圖像并自動上傳至新浪微博
- Python:簡單的攝像頭程序實現
- Python:日志模塊logging的應用
- Python:操作嵌入式數據庫SQLite
- Python:將句子中的單詞全部倒排過來,但單詞的字母順序不變
- Python:語音處理,實現在線朗讀RFC文檔或本地文本文件
- Python:通過計算階乘來學習lambda和reduce這兩個函數的使用
- Python:通過執行100萬次打印來比較C和python的性能,以及用C和python結合來解決性能問題的方法
- Python:使用matplotlib繪制圖表
- Python:使用pycha快速繪制辦公常用圖(餅圖、垂直直方圖、水平直方圖、散點圖等七種圖形)
- Python:使用pycha快速繪制辦公常用圖二(使用樣式定制個性化圖表)
- Python:監控鍵盤輸入、鼠標操作,并將捕獲到的信息記錄到文件中
- Python:通過獲取淘寶賬號和密碼的實驗,來看登陸方式選擇的重要性
- Python:通過獲取淘寶賬號和密碼的實驗,來看登陸方式選擇的重要性(二)
- Python:通過遠程監控用戶輸入來獲取淘寶賬號和密碼的實驗(一)
- Python:通過遠程監控用戶輸入來獲取淘寶賬號和密碼的實驗(二)
- Python:通過自定義系統級快捷鍵來控制程序運行
- Python:通過自定義系統級快捷鍵來控制程序開始或停止記錄日志(使用小技巧解決一個貌似無解的問題)
- Python:一個多功能的抓圖工具開發(附源碼)
- Python:程序發布方式簡介一(打包為可執行文件EXE)
- Python:新浪微博應用開發簡介(認證及授權部分)
- Python:程序最小化到托盤功能實現
- Python:實用抓圖工具開發介紹(含需求分析、設計、編碼、單元測試、打包、系統測試、發布各環節)
- Python:桌面氣泡提示功能實現
- Python:未來三個月的python學習計劃
- Python:pygame模塊及SDL庫簡介
- Python:獲取新浪微博用戶的收聽列表和粉絲列表
- Python:pygame游戲編程之旅一(Hello World)
- Python:pygame游戲編程之旅二(自由移動的小球)
- Python:pygame游戲編程之旅三(玩家控制的小球)
- Python:pygame游戲編程之旅四(游戲界面文字處理)
- Python:pygame游戲編程之旅五(游戲界面文字處理詳解)
- Python:pygame游戲編程之旅六(游戲中的聲音處理)
- Python:pygame游戲編程之旅七(pygame基礎知識講解1)
- Python:編程“八榮八恥”之我見
- Python:腳本的幾種執行方式
- wxPython:簡單的wxPython程序
- wxPython:簡單的wxPython程序的另一種寫法
- wxPython:應用程序對象介紹
- wxPython:輸出重定向
- wxPython:關閉wxPython程序
- wxPython:Frame類介紹
- wxPython:面板Panel的使用
- wxPython:工具欄、狀態欄、菜單實現
- wxPython:消息對話框MessageDialog
- wxPython:文本對話框TextEntryDialog
- wxPython:列表選擇框SingleChoiceDialog
- wxPython:事件處理介紹一
- wxPython:事件處理介紹二
- wxPython: 簡單的繪圖例子
- wxPython:狀態欄介紹
- wxPython:菜單介紹
- wxPython:文件對話框wx.FileDialog
- wxPython:顏色選擇對話框wx.ColourDialog
- wxPython:布局管理器sizer介紹
- wxPython:啟動畫面SplashScreen介紹
- wxPython:繪畫按鈕BitmapButton介紹
- wxPython:進度條Gauge介紹
- Python: 發送新浪微博(使用oauth2)
- Python:讀取新浪微博收聽列表
- Python:DNS客戶端實現