Loggiing日誌

来源:https://www.cnblogs.com/2678066103hs/p/18381595
-Advertisement-
Play Games

日誌處理logging 一、日誌輸出 日誌預設的輸出等級為:waring級別及以上的等級 修改日誌的預設輸出等級通過logging.basicConfig(level='INFO') 記錄日誌列印時間:logging.basicConfig(format=console_fmt) console_f ...


日誌處理logging

一、日誌輸出

  1. 日誌預設的輸出等級為:waring級別及以上的等級

  2. 修改日誌的預設輸出等級通過logging.basicConfig(level='INFO')

  3. 記錄日誌列印時間:logging.basicConfig(format=console_fmt)

    console_fmt = "%(name)s--->%(levelname)s--->%(asctime)s--->%(message)s--->%(lineno)d"

    • %(name)s 名字
    • %(levelname)s 日誌級別
    • %(asctime)s 列印時間,年月日十分秒
    • %(message)s 日誌中的信息
    • %(lineno)d 報錯日誌在代碼中第幾行
  4. logging.basicConfig(format=console_fmt,level='INFO')

# -*- coding: utf-8 -*-

import logging

logger = logging.getLogger(__name__)
console_fmt = "%(name)s--->%(levelname)s--->%(asctime)s--->%(message)s--->%(lineno)d"

logging.basicConfig(level="INFO",format=console_fmt)

logging.debug("debug")
logging.info("info")
logging.warning("warning")
logging.error("error")
logging.critical("critical")

二、日誌輸出到控制台

# Time:2022 2022/3/1 17:20
# Author: Jasmay
# -*- coding: utf-8 -*-

import logging

# 第一步:創建日誌器對象,預設等級為warning
logger = logging.getLogger("這是我的一個小測試日誌")
logging.basicConfig(level="INFO")

# 第二步:創建控制台日誌處理器
console_handler = logging.StreamHandler()

# 第三步:設置控制台日誌的輸出級別,需要日誌器也設置日誌級別為info;----根據兩個地方的等級進行對比,取日誌器的級別
console_handler.setLevel(level="WARNING")

# 第四步:設置控制台日誌的輸出格式
console_fmt = "%(name)s--->%(asctime)s--->%(message)s--->%(lineno)d"
fmt1 = logging.Formatter(fmt=console_fmt)
console_handler.setFormatter(fmt=fmt1)

# 第五步:將控制台日誌器,添加進日誌器對象中
logger.addHandler(console_handler)


logger.debug("---debug")
logger.info("---info")
logger.warning("---warning")
logger.error("---error")
logger.critical("---critical")

三、輸出到日誌文件

# Time:2022 2022/3/1 17:44
# Author: Jasmay
# -*- coding: utf-8 -*-

# Time:2022 2022/3/1 17:20
# Author: Jasmay
# -*- coding: utf-8 -*-

import logging

# 第一步:創建日誌器對象,預設等級為warning
logger = logging.getLogger("這是我的一個小測試日誌")
logging.basicConfig(level="INFO")

# 第二步:創建文件日誌處理器
file_handler = logging.FileHandler("./log.txt",mode="a",encoding="utf-8")

# 第三步:設置控制台日誌的輸出級別,需要日誌器也設置日誌級別為info;----根據兩個地方的等級進行對比,取日誌器的級別


# 第四步:設置控制台日誌的輸出格式
file_fmt = "%(name)s--->%(levelname)s--->%(asctime)s--->%(message)s"

fmt2 = logging.Formatter(fmt = file_fmt)

file_handler.setFormatter(fmt = fmt2)

# 第五步:將文件日誌器,添加進日誌器對象中
logger.addHandler(file_handler)



logger.debug("---debug")
logger.info("---info")
logger.warning("---warning")
logger.error("---error")
logger.critical("---critical")

四、同時輸出到控制台+文件

# Time:2022 2022/3/1 17:20
# Author: Jasmay
# -*- coding: utf-8 -*-

import logging

# 第一步:創建日誌器對象,預設等級為warning
logger = logging.getLogger("這是我的一個小測試日誌")
logging.basicConfig(level="INFO")

# 第二步:創建控制台日誌處理器+文件日誌處理器
console_handler = logging.StreamHandler()
file_handler = logging.FileHandler("./log.txt",mode="a",encoding="utf-8")

# 第三步:設置控制台日誌的輸出級別,需要日誌器也設置日誌級別為info;----根據兩個地方的等級進行對比,取日誌器的級別
console_handler.setLevel(level="WARNING")

# 第四步:設置控制台日誌和文件日誌的輸出格式
console_fmt = "%(name)s--->%(levelname)s--->%(asctime)s--->%(message)s--->%(lineno)d"
file_fmt = "%(lineno)d--->%(name)s--->%(levelname)s--->%(asctime)s--->%(message)s"

fmt1 = logging.Formatter(fmt = console_fmt)
fmt2 = logging.Formatter(fmt = file_fmt)

console_handler.setFormatter(fmt = fmt1)
file_handler.setFormatter(fmt = fmt2)

# 第五步:將控制台日誌器、文件日誌器,添加進日誌器對象中
logger.addHandler(console_handler)
logger.addHandler(file_handler)



logger.debug("---debug")
logger.info("---info")
logger.warning("---warning")
logger.error("---error")
logger.critical("---critical")

五、日誌類:將日誌輸出到控制台+文件

# Time:2022 2022/3/2 10:21
# Author: Jasmay
# -*- coding: utf-8 -*-
import logging

class Logger():
    def __init__(self,level="DEBUG"):
        # 創建日誌器對象
        self.logger = logging.getLogger(__name__)
        self.logger.setLevel(level)

    def console_handler(self,level="DEBUG"):
        # 創建控制台的日誌處理器
        console_handler = logging.StreamHandler()
        console_handler.setLevel(level)

        # 處理器添加輸出格式
        console_handler.setFormatter(self.get_formatter()[0])

        # 返回控制器
        return console_handler

    def file_handler(self, level="DEBUG"):
        # 創建文件的日誌處理器
        file_handler = logging.FileHandler("./log.txt",mode="a",encoding="utf-8")
        file_handler.setLevel(level)

        # 處理器添加輸出格式
        file_handler.setFormatter(self.get_formatter()[1])

        # 返回控制器
        return file_handler

    def get_formatter(self):
        """格式器"""

        console_fmt = logging.Formatter(fmt="%(name)s--->%(levelname)s--->%(asctime)s--->%(message)s")
        file_fmt = logging.Formatter(fmt="%(lineno)d--->%(name)s--->%(levelname)s--->%(asctime)s--->%(message)s")

        # 返回的是一個元組
        return console_fmt,file_fmt

    def get_log(self):
        # 日誌器中添加控制台處理器
        self.logger.addHandler(self.console_handler())
        # 日誌器中添加文件處理器
        self.logger.addHandler(self.file_handler())

        # 返回日誌實例對象
        return self.logger

六、調用日誌類:將日誌輸出到控制台+文件

# Time:2022 2022/3/2 10:45
# Author: Jasmay
# -*- coding: utf-8 -*-
from common.logone import Logger

class TestLog():
    def __init__(self):
        log = Logger()
        self.logger = log.get_log()
    def test_baili_01(self):
        self.logger.info("開始執行")
        self.logger.warning("結束執行")

# 實例化
test  = TestLog()
# 調用類中的方法
test.test_baili_01()

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

-Advertisement-
Play Games
更多相關文章
  • @目錄1.工作空間目錄2.載入環境變數3.打開CLion4.配置CLion5.編譯和調試軟體包 1.工作空間目錄 我們的一個工作空間目錄應該是這樣的 2.載入環境變數 先進入工作空間再載入 source ./devel/setup.bash 3.打開CLion 一定要在第二步的同一個終端下 clio ...
  • @目錄1.流程2.自定義請求和響應的數據2.1 std_msgs內置類型2.2 編寫.srv文件2.3 修改package.xml文件2.4 修改CMakeLists.txt文件2.4.1 修改find_package指令2.4.2 添加add_message_files指令2.4.3 添加gene ...
  • 所謂架構,意即系統架構,廣義上它涵蓋業務架構、運維架構、組織架構等所有系統構建場景,本文特指一般開發人員主要關註的開發架構。 關於架構的理論有很多,每個人也都有各自的理解,筆者相信很多人在實際運用中也會遇到各種各樣的問題和困惑,本文拋開教條,從一個實際項目的演化看何為架構。 項目背景 開始之前,先了 ...
  • @目錄1.配置Softerware & Updates2.添加軟體源3.設置key4.更新並安裝4.1 更新4.2 安裝(ros-noetic-desktop-full)4.2.1 安裝aptitude4.2.2 安裝ROS軟體包5.添加環境變數6.安裝構建依賴7.初始化和更新7.1 初始化7.1. ...
  • UML類圖 UML類圖 是一種靜態的結構圖,描述了系統的類的集合,類的屬性和類之間的關係,可以簡化了人們對系統的理解。UML類圖 是系統分析和設計階段的重要產物,是系統編碼和測試的重要模型。 圖示 類 解析 圓角矩形框,它就代表一個類(Class) 類圖分為三層: 第一層顯示類的名稱,如果是抽象類, ...
  • @目錄1.工作空間目錄1.1 package.xml2.啟動節點的方式2.1 一次啟動一個2.2 一次啟動多個3.ROS常用命令3.1 增3.2 查3.3 執行3.3.1 載入環境變數3.3.2 運行節點3.4 查看計算圖4.創建功能包4.1 選擇工作目錄4.2 創建功能包目錄4.3 建立功能包 1 ...
  • @目錄1.rosnode1.1 rosnode ping1.1.1 測試所有節點的連接狀態1.1.2 測試到某個節點的連接狀態1.2 rosnode list1.3 rosnode info1.4 rosnode machine1.4.1 列出所有設備1.4.2 查看指定設備上的運行節點1.5 ro ...
  • @目錄1.節點初始化2.話題通信2.1 創建發佈者對象2.2 消息發佈2.3 創建訂閱者對象3.服務通信3.1 創建服務對象3.2 創建客戶對象3.3 客戶發送請求3.4 客戶對象等待服務4. 迴旋函數4.1 spin4.2 spinOnce5.時間5.1 時刻5.1.1 獲取當前時刻5.1.2 設 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...