人妖在线一区,国产日韩欧美一区二区综合在线,国产啪精品视频网站免费,欧美内射深插日本少妇

新聞動態(tài)

Python基礎之logging模塊知識總結

發(fā)布日期:2022-07-05 14:30 | 文章來源:gibhub

logging模塊是Python內置的標準模塊,主要用于輸出腳本運行日志,可以設置輸出日志的等級、日志保存路徑等。

  • 可以通過設置不同的日志等級,在 release 版本中只輸出重要信息,而不顯示大量的調試信息
  • logging 可以決定將信息輸出位置和內容
  • logging 線程更安全

一、日志級別

級別排序:CRITICAL > ERROR > WARNING > INFO > DEBUG

  • debug : 打印全部日志,詳細信息,通常只出現在診斷問題
  • info : 打印info,warning,error,critical級別的日志,正常輸出
  • warning : 打印warning,error,critical級別的日志,部分異常,不影響程序
  • error : 打印error,critical級別的日志,影響程序部分功能
  • critical : 打印critical級別,影響程序運行
import logging  # 引入logging模塊
# 將信息打印到控制臺上
logging.debug("debug")
logging.info("info")
logging.warning("warning")
logging.error("error")
logging.critical("critical")
[root@zijie ~]# python log.py
WARNING:root:warning
ERROR:root:error
CRITICAL:root:critical

默認生成的root logger的level是logging.WARNING,低于該級別不輸出,如果要展示低于WARNING級別的內容,可以引入logging.basicConfig指定日志級別logging.basicConfig(level=logging.DEBUG)

二、basicConfig

格式 描述
filename 指定使用指定的文件名而不是 StreamHandler 創(chuàng)建 FileHandler。
filemode 如果指定 filename,則以此模式打開文件(‘r'、‘w'、‘a')。默認為“a”。
format 為處理程序使用指定的格式字符串。
datefmt 使用 time.strftime() 所接受的指定日期/時間格式。
style 如果指定了格式,則對格式字符串使用此樣式。'%' 用于 printf 樣式、'{' 用于 str.format()、'$' 用于 string。默認為“%”。
level 將根記錄器級別設置為指定的級別。默認生成的 root logger 的 level 是 logging.WARNING,低于該級別的就不輸出了。級別排序:CRITICAL > ERROR > WARNING > INFO > DEBUG。(如果需要顯示所有級別的內容,可將 level=logging.NOTSET)
stream 使用指定的流初始化 StreamHandler。注意,此參數與 filename 不兼容——如果兩者都存在,則會拋出 ValueError。
handlers 如果指定,這應該是已經創(chuàng)建的處理程序的迭代,以便添加到根日志程序中。任何沒有格式化程序集的處理程序都將被分配給在此函數中創(chuàng)建的默認格式化程序。注意,此參數與 filename 或 stream 不兼容——如果兩者都存在,則會拋出 ValueError。
import logging
logging.basicConfig(level=logging.INFO,
  format='%(asctime)s %(filename)s %(levelname)s %(message)s',
  datefmt='%a %d %b %Y %H:%M:%S',
  filename='xuehui.log',
  filemode='w')
logging.info('This is a info.')
logging.debug('This is a debug message.')
logging.warning('This is a warning.')

三、日志寫文件

import logging
import os.path
import time
#創(chuàng)建logger
logger = logging.getLogger()
logger.setLevel(logging.DEBUG)
# 創(chuàng)建handler,用于寫入日志文件
logdate = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
log_path = 'logs/'
log_name = log_path + logdate + '.log'
logfile = log_name
fh = logging.FileHandler(logfile, mode='w')
fh.setLevel(logging.DEBUG)
# 定義輸出格式
formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
fh.setFormatter(formatter)
# 將logger添加到handler
logger.addHandler(fh)
# 日志
logger.debug('this is a logger debug message')
logger.info('this is a logger info message')
logger.warning('this is a logger warning message')
logger.error('this is a logger error message')
logger.critical('this is a logger critical message')

四、traceback記錄

import logging
import os.path
import time
#創(chuàng)建logger
logger = logging.getLogger()
logger.setLevel(logging.DEBUG)
# 創(chuàng)建handler,用于寫入日志文件
logdate = time.strftime('%Y%m%d%H%M%S', time.localtime(time.time()))
log_path = 'logs/'
log_name = log_path + logdate + '.log'
logfile = log_name
fh = logging.FileHandler(logfile, mode='w')
fh.setLevel(logging.DEBUG)
# 定義輸出格式
formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
fh.setFormatter(formatter)
# 將logger添加到handler
logger.addHandler(fh)
# 日志
try:
 open('/data/exist', 'rb')
except BaseException as e:
 logger.error('Failed to open file', exc_info=True)

到此這篇關于Python基礎之logging模塊知識總結的文章就介紹到這了,更多相關Python logging模塊內容請搜索本站以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持本站!

美國穩(wěn)定服務器

版權聲明:本站文章來源標注為YINGSOO的內容版權均為本站所有,歡迎引用、轉載,請保持原文完整并注明來源及原文鏈接。禁止復制或仿造本網站,禁止在非www.sddonglingsh.com所屬的服務器上建立鏡像,否則將依法追究法律責任。本站部分內容來源于網友推薦、互聯(lián)網收集整理而來,僅供學習參考,不代表本站立場,如有內容涉嫌侵權,請聯(lián)系alex-e#qq.com處理。

相關文章

實時開通

自選配置、實時開通

免備案

全球線路精選!

全天候客戶服務

7x24全年不間斷在線

專屬顧問服務

1對1客戶咨詢顧問

在線
客服

在線客服:7*24小時在線

客服
熱線

400-630-3752
7*24小時客服服務熱線

關注
微信

關注官方微信
頂部