电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁技術文章
文章詳情頁

Python logging模塊原理解析及應用

瀏覽:76日期:2022-07-14 10:47:54

一、logging日志模塊等級

常見log級別從高到低:

CRITICAL 》ERROR 》WARNING 》INFO 》DEBUG,默認等級為WARNING,即>=WARNING級別的log才輸出。

日志等級(level) 描述 CRITICAL 當發(fā)生嚴重錯誤,導致應用程序不能繼續(xù)運行時記錄的信息 ERROR 由于一個更嚴重的問題導致某些功能不能正常運行時記錄的信息 WARNING 當某些不期望的事情發(fā)生時記錄的信息(如,磁盤可用空間較低),但是此時應用程序還是正常運行的 INFO 信息詳細程度僅次于DEBUG,通常只記錄關鍵節(jié)點信息,用于確認一切都是按照我們預期的那樣進行工作 DEBUG 最詳細的日志信息,典型應用場景是 問題診斷

二、logging模塊的使用方式介紹

logging模塊提供了兩種記錄日志的方式:

第一種方式是使用logging提供的模塊級別的函數(shù) 第二種方式是使用Logging日志系統(tǒng)的四大組件

其實,logging所提供的模塊級別的日志記錄函數(shù)也是對logging日志系統(tǒng)相關類的封裝而已。

(1)logging模塊定義的模塊級別的常用函數(shù)

函數(shù) 說明 logging.debug(msg, *args, **kwargs) 創(chuàng)建一條嚴重級別為DEBUG的日志記錄 logging.info(msg, *args, **kwargs) 創(chuàng)建一條嚴重級別為INFO的日志記錄 logging.warning(msg, *args, **kwargs) 創(chuàng)建一條嚴重級別為WARNING的日志記錄 logging.error(msg, *args, **kwargs) 創(chuàng)建一條嚴重級別為ERROR的日志記錄 logging.critical(msg, *args, **kwargs) 創(chuàng)建一條嚴重級別為CRITICAL的日志記錄 logging.log(level, *args, **kwargs) 創(chuàng)建一條嚴重級別為level的日志記錄 logging.basicConfig(**kwargs) 對root logger進行一次性配置

其中l(wèi)ogging.basicConfig(**kwargs)函數(shù)用于指定“要記錄的日志級別”、“日志格式”、“日志輸出位置”、“日志文件的打開模式”等信息,其他幾個都是用于記錄各個級別日志的函數(shù)。

(2)logging模塊的四大組件

組件 說明 loggers 提供應用程序代碼直接使用的接口 handlers 用于將日志記錄發(fā)送到指定的目的位置 filters 提供更細粒度的日志過濾功能,用于決定哪些日志記錄將會被輸出(其它的日志記錄將會被忽略) formatters 用于控制日志信息的最終輸出格式

三、自定義Logger模塊類

# testLog1.pyimport loggingimport timeclass Logger(): def __init__(self, logger, level=logging.DEBUG): ’’’ : 自定義Logger模塊類 : logger: logger名 : level: 日志級別 ’’’ # 創(chuàng)建一個logger self.logger = logging.getLogger(logger) self.logger.setLevel(level) # 定義handler的輸出格式 curr_time = time.strftime('%Y-%m-%d') self.LogFileName = ’log’ + curr_time + ’.txt’ fmt = logging.Formatter(’%(asctime)s - %(filename)s:[%(lineno)s] - [%(levelname)s] - %(message)s’) # asctime: 日志事件發(fā)生的時間 # filename: 源文件的名稱部分,包含文件后綴 # lineno: 調用日志記錄函數(shù)的源代碼所在的行號 # evelname: 該日志記錄的文字形式的日志級別 # message: 日志記錄的文本內容 # 創(chuàng)建一個handler, 用于寫入日志文件 fh = logging.FileHandler(self.LogFileName) fh.setLevel(logging.DEBUG) fh.setFormatter(fmt) # 再創(chuàng)建一個handler,用于輸出到控制臺 ch = logging.StreamHandler() ch.setLevel(logging.DEBUG) ch.setFormatter(fmt) # 給logger添加handler self.logger.addHandler(fh) self.logger.addHandler(ch) # level優(yōu)先級 # logger.setLevel > handler.setLevel > logging.basicConfigif __name__ == '__main__': log = Logger(__name__, level=logging.DEBUG) log.logger.debug(’debug’) log.logger.log(logging.DEBUG, ’debug’)# 執(zhí)行testLog1.py,則控制臺輸出如下:2020-08-03 20:36:47,104 - testLog1.py:[117] - [DEBUG] - debug2020-08-03 20:36:47,104 - testLog1.py:[118] - [DEBUG] - debug# 日志文件記錄如下:2020-08-03 20:36:15,982 - testLog1.py:[117] - [DEBUG] - debug2020-08-03 20:36:15,982 - testLog1.py:[118] - [DEBUG] - debug

# testLog2.pyfrom testLog1 import Loggerimport tracebacklog = Logger(__name__)def func(): try: assert 1==2 except Exception: log.logger.info(’測試失敗,輸出信息如下:{}’.format(traceback.format_exc()))# traceback.format_exc() 會返回異常信息的字符串if __name__ == '__main__': func()# 執(zhí)行testLog2.py,則控制臺輸出如下:2020-08-03 20:43:44,907 - testLog2.py:[11] - [INFO] - 測試失敗,輸出信息如下:Traceback (most recent call last): File 'E:/imooc/testLog.py', line 9, in func assert 1==2AssertionError# 日志文件記錄如下:2020-08-03 20:43:44,907 - testLog2.py:[11] - [INFO] - 測試失敗,輸出信息如下:Traceback (most recent call last): File 'E:/imooc/testLog.py', line 9, in func assert 1==2AssertionError

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 汽车整车综合环境舱_军标砂尘_盐雾试验室试验箱-无锡苏南试验设备有限公司 | 广州食堂承包_广州团餐配送_广州堂食餐饮服务公司 - 旺记餐饮 | 郑州大巴车出租|中巴车租赁|旅游大巴租车|包车|郑州旅游大巴车租赁有限公司 | 安平县鑫川金属丝网制品有限公司,防风抑尘网,单峰防风抑尘,不锈钢防风抑尘网,铝板防风抑尘网,镀铝锌防风抑尘网 | 大功率金属激光焊接机价格_不锈钢汽车配件|光纤自动激光焊接机设备-东莞市正信激光科技有限公司 定制奶茶纸杯_定制豆浆杯_广东纸杯厂_[绿保佳]一家专业生产纸杯碗的厂家 | 二手注塑机回收_旧注塑机回收_二手注塑机买卖 - 大鑫二手注塑机 二手光谱仪维修-德国OBLF光谱仪|进口斯派克光谱仪-热电ARL光谱仪-意大利GNR光谱仪-永晖检测 | 医学动画公司-制作3d医学动画视频-医疗医学演示动画制作-医学三维动画制作公司 | 防水试验机_防水测试设备_防水试验装置_淋雨试验箱-广州岳信试验设备有限公司 | 冷水机,风冷冷水机,水冷冷水机,螺杆冷水机专业制造商-上海祝松机械有限公司 | 电渗析,废酸回收,双极膜-山东天维膜技术有限公司 | 电销卡 防封电销卡 不封号电销卡 电话销售卡 白名单电销卡 电销系统 外呼系统 | 列管冷凝器,刮板蒸发器,外盘管反应釜厂家-无锡曼旺化工设备有限公司 | 万家财经_财经新闻_在线财经资讯网 | 发电机价格|发电机组价格|柴油发电机价格|柴油发电机组价格网 | BHK汞灯-百科|上海熙浩实业有限公司| 嘉兴泰东园林景观工程有限公司_花箱护栏| 制氮设备_PSA制氮机_激光切割制氮机_氮气机生产厂家-苏州西斯气体设备有限公司 | 硫酸钡厂家_高光沉淀硫酸钡价格-河南钡丰化工有限公司 | 小程序开发公司-小程序制作-微信小程序开发-小程序定制-咏熠软件 | 智慧养老_居家养老_社区养老_杰佳通 | 锂离子电池厂家-山东中信迪生电源 | 2025福建平潭岛旅游攻略|蓝眼泪,景点,住宿攻略-趣平潭网 | 上海公司注册-代理记账-招投标审计-上海昆仑扇财税咨询有限公司 上海冠顶工业设备有限公司-隧道炉,烘箱,UV固化机,涂装设备,高温炉,工业机器人生产厂家 | 网优资讯-为循环资源、大宗商品、工业服务提供资讯与行情分析的数据服务平台 | 耐力板-PC阳光板-PC板-PC耐力板 - 嘉兴赢创实业有限公司 | B2B网站_B2B免费发布信息网站_B2B企业贸易平台 - 企资网 | 酵素生产厂家_酵素OEM_酵素加盟_酵素ODM_酵素原料厂家_厦门益力康 | 山东集装箱活动房|济南集装箱活动房-济南利森集装箱有限公司 | 常州律师事务所_常州律所_常州律师-江苏乐天律师事务所 | 安平县鑫川金属丝网制品有限公司,防风抑尘网,单峰防风抑尘,不锈钢防风抑尘网,铝板防风抑尘网,镀铝锌防风抑尘网 | 深圳宣传片制作-企业宣传视频制作-产品视频拍摄-产品动画制作-短视频拍摄制作公司 | 烟台螺纹,烟台H型钢,烟台钢材,烟台角钢-烟台市正丰金属材料有限公司 | 土壤养分检测仪|土壤水分|土壤紧实度测定仪|土壤墒情监测系统-土壤仪器网 | 注塑模具_塑料模具_塑胶模具_范仕达【官网】_东莞模具设计与制造加工厂家 | 低温等离子清洗机(双气路进口)-嘉润万丰 | 精密模具制造,注塑加工,吹塑和吹瓶加工,EPS泡沫包装生产 - 济南兴田塑胶有限公司 | 福建自考_福建自学考试网 | 镀锌钢格栅_热镀锌格栅板_钢格栅板_热镀锌钢格板-安平县昊泽丝网制品有限公司 | 气体热式流量计-定量控制流量计(空气流量计厂家)-湖北南控仪表科技有限公司 | 高尔夫球杆_高尔夫果岭_高尔夫用品-深圳市新高品体育用品有限公司 | 正压送风机-多叶送风口-板式排烟口-德州志诺通风设备 |