創(chuàng)新互聯(lián)www.cdcxhl.cn八線動態(tài)BGP香港云服務(wù)器提供商,新人活動買多久送多久,劃算不套路!
10年積累的成都做網(wǎng)站、網(wǎng)站制作、成都外貿(mào)網(wǎng)站建設(shè)經(jīng)驗,可以快速應(yīng)對客戶對網(wǎng)站的新想法和需求。提供各種問題對應(yīng)的解決方案。讓選擇我們的客戶得到更好、更有力的網(wǎng)絡(luò)服務(wù)。我雖然不認(rèn)識你,你也不認(rèn)識我。但先建設(shè)網(wǎng)站后付款的網(wǎng)站建設(shè)流程,更有豐都免費網(wǎng)站建設(shè)讓你可以放心的選擇與我們合作。這篇文章給大家分享的是有關(guān)python記錄日志的方法的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。
為什么使用 logging 模塊?
也許會有開發(fā)者會問,為什么不是簡單的 print 語句呢? Logging 模塊有很多優(yōu)勢,包括:
多線程支持
通過不同級別的日志分類
靈活性和可配置性
將如何記錄日志與記錄什么內(nèi)容分離
最后一點,將我們記錄內(nèi)容從記錄方式中真正分離,保證了軟件不同部分的合作。舉個例子,它允許一個框架或庫的開發(fā)者增加日志并且讓系統(tǒng)管理員或負(fù)責(zé)運行配置的人員決定稍后應(yīng)該記錄什么。
使用起來還是很方便的。
#!/usr/bin/env python # -*- coding: utf-8 -*- import logging # create a log file logger = logging.getLogger('atp_log') logger.setLevel(logging.DEBUG) # create a handler, write the log info into it fh = logging.FileHandler('atp.log') fh.setLevel(logging.DEBUG) # create another handler output the log though console ch = logging.StreamHandler() ch.setLevel(logging.DEBUG) # 定義handler的輸出格式 formatter = logging.Formatter('%(asctime)s - %(levelname)s - %(message)s') fh.setFormatter(formatter) ch.setFormatter(formatter) # 給logger添加handler logger.addHandler(fh) logger.addHandler(ch) # 記錄一條日志 logger.info('foorbar') logger.error('foorbar')
之后,我們隊logger輸入info warning或者error都可以,而且會被記錄在日志文件里面。當(dāng)然,上面的代碼中,我們在設(shè)置
fh = logging.FileHandler('atp.log')
這個文件的logger也創(chuàng)建了一個從console的日志顯示的地方。
ch = logging.StreamHandler()
之后,我們就可以看到在文件和console中都會有相應(yīng)的信息出現(xiàn)。
感謝各位的閱讀!關(guān)于python記錄日志的方法就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!