python學習筆記二:(python3 logging函數中format說明)


  • 背景,在學習logging時總是遇到無法理解的問題,總結,嘗試一下更清晰明了了,讓我們開始吧!

                                                        

  • logging模塊常用format格式說明

  • %(levelno)s: 打印日志級別的數值
  • %(levelname)s: 打印日志級別名稱
  • %(pathname)s: 打印當前執行程序的路徑,其實就是sys.argv[0]
  • %(filename)s: 打印當前執行程序名,python如:login.py
  • %(funcName)s: 打印日志的當前函數
  • %(lineno)d: 打印日志的當前行號,在第幾行打印的日志
  • %(asctime)s: 打印日志的時間
  • %(thread)d: 打印線程ID
  • %(threadName)s: 打印線程名稱
  • %(process)d: 打印進程ID
  • %(message)s: 打印日志信息
  • 使用前理解:

    1. logging.basicConfig函數各參數:
    2.  filename: 指定日志文件名,如my.log 或my.txt
    3.  filemode: 和file函數意義相同,指定日志文件的打開模式, 'w'或'a'
    4. format: 指定輸出的格式和內容,format可以輸出很多有用信息,如下例所示:
    5. datefmt: 指定時間格式,同time.strftime()
    6. level: 設置日志級別,默認為logging.WARNING
    7. stream: 指定將日志的輸出流,可以指定輸出到sys.stderr,sys.stdout或者文件,默認輸出到sys.stderr,當stream和filename同時指定時,stream被忽略

logging中使用format:

例1:指定文件測試
logging.basicConfig(level=logging.DEBUG,
format='%(asctime)s %(filename)s [line:%(lineno)d] %(levelname)s %(message)s',
datefmt='%a, %d %b %Y %H:%M:%S',
filename='myapp.txt',
filemode='w')
logging.debug("這是一個debug")

執行結果:

 

例2:不指定文件,在窗口打印日志

logging.basicConfig(level=logging.DEBUG,
format='%(asctime)s %(thread)d %(threadName)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
datefmt='%a, %d %b %Y %H:%M:%S',
filemode='w')

執行結果:

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM