Python連載29-log的使用需求實現舉例

来源:https://www.cnblogs.com/ruigege0000/archive/2019/08/07/11312727.html
-Advertisement-
Play Games

一、Format類 1.直接實例化 2.可以繼承Format添加特殊字元 3.三個參數 (1)fmt:指定消息格式化字元串,如果不指定該參數則預設使用message的原始值 (2)datemt:指定日期格式字元串,如果不指定該參數,則預設使用“%Y-%m-%d %H:%M:%S" (3)style: ...


一、Format類

1.直接實例化

2.可以繼承Format添加特殊字元

3.三個參數

(1)fmt:指定消息格式化字元串,如果不指定該參數則預設使用message的原始值

(2)datemt:指定日期格式字元串,如果不指定該參數,則預設使用“%Y-%m-%d %H:%M:%S"

(3)style:Python3.2新增的參數,可取值為”%“,“{”和“¥”,如果不指定預設使用“%”

二、Filter類

1.可以被Handler和Logger使用

2.控制傳遞過來的信息的具體內容。

三、例子

#現在有一下幾個日誌記錄的需求:

#(1)要求將所有級別的所有日誌寫入磁碟文件

#(2)all.log文件中記錄所有的日誌信息,日誌格式為:日期和時間-日誌級別-日誌信息

#(3)error.log文件中單獨記錄error及以上級別的日誌信息,日誌格式:日期和時間-日誌級別-文件名【:行號】- 日誌信息

#(4)要求all.log在每天凌晨進行日誌切割

#分析

#(1)要記錄所有級別的日誌,因此日誌器的有效level需要設置為最低級別  --DEBUG

#(2)日誌需要被髮送到兩個不同的目的地,因此需要為日誌設置兩個handler;另外。兩個目的地都是磁碟文件。因此這兩個handler都是與fileHander

#(3)all.log要求按照時間進行日誌切割,因此它需要logging.handler.TimeRotatingFileHandler;而error.log沒有要求日誌切割。因此

#(4)兩個日誌文件的格式不同,因此需要對兩個handler分別進行設置格式器

 

import logger

import logging.handlers

import datetime

#定義Logger

logger = logging.getLogger("mylogger")

logging.setLevel(logging.DEBUG)

 

rf_handler = logging.handlers.TimedRotatingFileHandler("all.log",when="midnight",interval=1,backupCount=7,atTime=None)

rf_handler.setFormatter(logging.Formatter("%(asctime)s-%(levelname)s-%(message)s"))

 

f_handler = logging.FileHandler("error.log")

f_handler = setLevel(logging.ERROR)

f_handler.setFormat(logging.Formatter("%(asctime)s-%(levelname)s-%(filename)s[:%(lineno)d-%(message)s)")

 

#把相應的處理器組裝到logger上

logger.addHandler(rf_handler)

logger.addHandler(f_handler)

 

logger.debug("debug message")

logger.info("info message")

logger.warning("warning message")

logger.error("error message")

logger.critical("critical message")

 

 

四、源碼

d23_3_log_example.py

地址:https://github.com/ruigege66/Python_learning/blob/master/d23_3_log_example.py

2.CSDN:https://blog.csdn.net/weixin_44630050(心悅君兮君不知-睿)

3.博客園:https://www.cnblogs.com/ruigege0000/

4.歡迎關註微信公眾號:傅里葉變換

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 迪米特原則定義 迪米特原則,也叫最少知道原則,即一個類應該 對自己依賴的類知道的越少越好 ,而你被依賴的類多麼複雜,對我都沒有關係。也就是說,對於別依賴的類來說,不管業務邏輯多麼複雜,都應該儘量封裝在類的內部;對外除了必備的public方法,不再泄露任何信息。 1.問題由來 我們知道,類和類是有耦合 ...
  • 最近同事在處理文件導入的時候需要把一批文件換成CSV的格式,但是直覺修改尾碼是不生效的,而且xlsx和xls的文件沒法直接換成CVS的文件,所以找了一下方式,並且自己實現了python的轉換方式。代碼如下 文件需要導入pandas 還要引入xlrd 代碼是基於python3.6的環境。 ...
  • 實例解讀面向對象核心,所有例子基於 C#,涉及我們實務中最常關心的問題: 1、封裝、繼承、多態; 2、抽象類、介面; 3、委托、事件。 ...
  • 前幾天和隔壁鄰居玩鬥地主被髮現了,牌被沒收了,鬥地主是鬥不了了,但我還想和鄰居玩耍。 想破腦袋終於讓我想到一個游戲,數獨!什麼叫數獨?數獨就是可以讓我趁老王不在的時候和隔壁鄰居一起玩耍的游戲! ...
  • 土壤濕度感測器和dh11會獲取數據,然後樹莓派會處理這些數據,讀出土壤溫濕度和空氣溫濕度,並將這些數據上傳到雲伺服器, 雲伺服器會將這些數據顯示在網頁上,同時樹莓派會根據這些數據來決定是否控制繼電器進而控制水泵來澆水,當然,水泵是否澆水也可以通過事先做的網頁看到。 ...
  • https://www.datamentor.io/r-programming/data-frame/ Check if a variable is a data frame or not We can check if a variable is a data frame or not using ...
  • 通過實現 Aware 介面,可以在 Spring 啟動時,調用介面定義的方法,將 Spring 底層的一些組件註入到自定義的 Bean 中。 下麵列出了幾個 Spring 在 Aware 介面基礎上,進行擴展的介面,分別會在創建 Bean 時直接執行,或者通過 BeanPostProcessor 間 ...
  • 上一篇博客的最後簡單提了下CommitLog的刷盤 【RocketMQ中Broker的消息存儲源碼分析】 (這篇博客和上一篇有很大的聯繫) Broker的CommitLog刷盤會啟動一個線程,不停地將緩衝區的內容寫入磁碟(CommitLog文件)中,主要分為非同步刷盤和同步刷盤 非同步刷盤又可以分為兩種 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...