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層級,即使系統正常運行以後也不能保證有未預料的錯誤產生,一旦選擇低層級的日誌很可能會漏記重要的系統異常的原因