import logging ''' 日志級別: critical > error > warning > info > debug,notset 級別越高打印的日志越少,反之亦然,即 debug : 打印全部的日志(notset等同於debug) info : 打印info,warning,error,critical級別的日志 warning : 打印warning,error,critical級別的日志 error : 打印error,critical級別的日志 critical : 打印critical級別 ''' handler=logging.FileHandler("/tmp/TNLOG-error.log") def log(level): logger = logging.getLogger() #不能重復創建handler,否則會重復寫入同樣的記錄? logger.addHandler(handler) logger.setLevel(level) logger.debug("debug") logger.info("info") logger.warning("warning") logger.error("error") logger.critical("critical\n") if __name__ == "__main__": log(logging.NOTSET) log(logging.DEBUG) log(logging.INFO) log(logging.WARNING) log(logging.ERROR) log(logging.CRITICAL)
在程序開發階段,顯然我們需要大量的日志,因此日志級別應為debug,等系統逐漸穩定,我們需要記錄的日志應該減少一些,這樣可以提高程序執行效率(我覺得似乎不應該刪除debug級別的日志語句,因為維護時會再度需要?雖然讓代碼變長,我認為好的系統應該有這樣的語句在)這個時候,我們更關心用戶在系統里的動作,用戶做了什么,如果我們的程序是一個可以買東西的網站,我們需要記錄一切與錢有關的信息,即用戶對於核心數據的修改,我們必須記錄在案,這個時候我們可以選擇info和info以上級別的日志,最重要的信息,顯然我們需要選擇critical級別,具體怎么划分看系統的設計,我也沒有太多經驗就先不說了,不過異常部分(try-except)我建議還是使用error級別,即使系統正常運行以后也不能保證有未預料的錯誤產生,一旦選擇低級別的日志很可能會漏記重要的系統異常的原因
