在线观看www成人影院-在线观看www日本免费网站-在线观看www视频-在线观看操-欧美18在线-欧美1级

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復(fù)
登錄后你可以
  • 下載海量資料
  • 學(xué)習(xí)在線課程
  • 觀看技術(shù)視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認(rèn)識你,還能領(lǐng)取20積分哦,立即完善>

3天內(nèi)不再提示

Python自制簡單實(shí)用的日志裝飾器

科技綠洲 ? 來源:Python實(shí)用寶典 ? 作者:Python實(shí)用寶典 ? 2023-10-21 14:39 ? 次閱讀

在寫代碼的時候,往往會漏掉日志這個關(guān)鍵因素,導(dǎo)致功能在使用的時候出錯卻無法溯源。

其實(shí),只需要寫一個非常簡單的日志裝飾器,我們就能大大提升排查問題的效率。

1.簡陋版裝飾器

寫一個裝飾器非常簡單,因?yàn)楸举|(zhì)上裝飾器就是一個返回函數(shù)的“高階”函數(shù)而已:

1) 函數(shù)作為參數(shù)傳遞進(jìn)裝飾器。
2) 裝飾器內(nèi)定義一個函數(shù),處理作為參數(shù)傳遞進(jìn)來的函數(shù)。
3) 返回這個裝飾器內(nèi)定義的函數(shù)

圖片

用一下試試看:

圖片

效果如下:

圖片

雖然這樣可以實(shí)現(xiàn)我們所需要的功能,但其實(shí)有很大的優(yōu)化空間。

2.普通版裝飾器

第一版代碼中有一個顯而易見的問題,裝飾器內(nèi)定義的處理函數(shù)不支持kwargs,而在裝飾器中支持kwargs僅僅是舉手之勞而已。

第二個問題是,生成時間戳的時候采用字符串截取的形式,這種形式過于粗暴。其實(shí)可以使用strftime做字符串轉(zhuǎn)換。

修改如下:

圖片

似乎優(yōu)化得差不多了,不過依然存在改進(jìn)空間。

3.優(yōu)化版裝飾器

在前兩版代碼中,我們使用print進(jìn)行日志輸出,其實(shí)這種處理日志的方式并不標(biāo)準(zhǔn)。

使用logging模塊控制日志輸出是一個更好地選擇。

為了使用logging模塊記錄日志,我們需要先配置好logging相關(guān)的選項(xiàng)。

1) 首先,生成一個日志記錄器,并配置日志等級:

圖片

2) 配置日志格式、增加handler控制輸出流:

圖片

此處可以設(shè)置handler所需要處理的日志等級,沒有設(shè)置則默認(rèn)使用logger自身的Level,即DEBUG等級。

3) 最后,將此handler加入到日志記錄器內(nèi):

圖片

logging 完整配置如下:

圖片

使用的時候非常簡單,就是把print換成logger.debug即可:

圖片

效果如下:

圖片

這樣,一個比較完善的日志裝飾器就完成了。

附常用的日志等級配置:

圖片

聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 字符串
    +關(guān)注

    關(guān)注

    1

    文章

    585

    瀏覽量

    20603
  • 函數(shù)
    +關(guān)注

    關(guān)注

    3

    文章

    4346

    瀏覽量

    62977
  • 日志
    +關(guān)注

    關(guān)注

    0

    文章

    139

    瀏覽量

    10679
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4807

    瀏覽量

    85040
收藏 人收藏

    評論

    相關(guān)推薦

    理解Python裝飾及其工作原理

    Python 是一種對新手很友好的語言。但是,它也有很多較難掌握的高級功能,比如裝飾(decorator)。很多初學(xué)者一直不理解裝飾及其
    發(fā)表于 10-08 11:39 ?2247次閱讀

    Python日志logging模塊簡單介紹

    Python日志logging模塊的使用-數(shù)據(jù)庫腳本優(yōu)化003
    發(fā)表于 03-05 13:46

    分享python 7個好用的裝飾

    、deco.concurrent安裝:pip install deco使用 DECO 就像在 Python 程序中查找或創(chuàng)建兩個函數(shù)一樣簡單。我們可以用 @concurrent 裝飾需要并行運(yùn)行的函數(shù)
    發(fā)表于 06-15 16:54

    自制簡單的星星花環(huán)

    描述簡單的星星花環(huán)今年我決定用自制的花環(huán)裝飾我的圣誕樹。為此,您需要取幾顆這樣的星星并通過電線將它們相互連接,這將傳輸 5 V 電源。每顆星上安裝了 5 個 LED 和 5 個額定值為 120 歐姆的限流電阻。PCB
    發(fā)表于 07-28 07:58

    一文讀懂Python裝飾

    裝飾前,還要先要明白一件事,Python 中的函數(shù)和 Java、C++不太一樣,Python 中的函數(shù)可以像普通變量一樣當(dāng)做參數(shù)傳遞給另外一個函數(shù)。
    發(fā)表于 04-28 10:48 ?3440次閱讀
    一文讀懂<b class='flag-5'>Python</b><b class='flag-5'>裝飾</b><b class='flag-5'>器</b>

    讓你學(xué)寫Python裝飾的五大理由

    你必須學(xué)寫Python裝飾的五個理由
    的頭像 發(fā)表于 03-02 10:06 ?1950次閱讀

    Python的函數(shù)裝飾器使用方法

    Python中的裝飾是一種可以裝飾其它對象的工具,簡單地說,他們是修改其他函數(shù)的功能的函數(shù)。該工具本質(zhì)上是一個可調(diào)用的對象(callabl
    的頭像 發(fā)表于 01-21 11:36 ?1633次閱讀
    <b class='flag-5'>Python</b>的函數(shù)<b class='flag-5'>裝飾</b>器使用方法

    Python裝飾的原理和案例

    Python中的裝飾器用于擴(kuò)展可調(diào)用對象的功能,而無需修改其結(jié)構(gòu)?;旧?,裝飾函數(shù)包裝另一個函數(shù)以增強(qiáng)或修改其行為。我們可以通過一個具體的例子了解基礎(chǔ)知識!讓我們編寫一個包含
    的頭像 發(fā)表于 07-01 11:35 ?2280次閱讀

    Python更優(yōu)雅的日志記錄解決方案Loguru

    ? Loguru: 更優(yōu)雅的日志記錄解決方案! loguru ?是一個? Python ?簡易且強(qiáng)大的第三方日志記錄庫,該庫旨在通過添加一系列有用的功能來解決標(biāo)準(zhǔn)記錄的注意事項(xiàng),從而
    的頭像 發(fā)表于 11-18 11:24 ?3058次閱讀

    自制PCB花環(huán)裝飾圣誕樹

    電子發(fā)燒友網(wǎng)站提供《自制PCB花環(huán)裝飾圣誕樹.zip》資料免費(fèi)下載
    發(fā)表于 07-18 09:42 ?2次下載
    <b class='flag-5'>自制</b>PCB花環(huán)<b class='flag-5'>裝飾</b>圣誕樹

    Python裝飾的使用

    定義 首先我們先來了解下裝飾的定義。顧名思義,在Python中,裝飾本質(zhì)上就是一個函數(shù),它可以接收一個函數(shù)作為參數(shù),然后返回一個新的函數(shù)
    的頭像 發(fā)表于 06-21 16:54 ?784次閱讀

    如何通過阿里云日志服務(wù)搭建一套通過Python上傳日志的監(jiān)控服務(wù)

    時間,因此如果能使用市面上現(xiàn)成的系統(tǒng)會很方便。 本文將教你如何通過阿里云日志服務(wù)搭建一套通過Python上傳日志、配置日志告警的監(jiān)控服務(wù)。 1.準(zhǔn)備 開始之前,你要確保
    的頭像 發(fā)表于 10-21 14:43 ?1021次閱讀
    如何通過阿里云<b class='flag-5'>日志</b>服務(wù)搭建一套通過<b class='flag-5'>Python</b>上傳<b class='flag-5'>日志</b>的監(jiān)控服務(wù)

    Python 自制簡單實(shí)用的日志裝飾

    在寫代碼的時候,往往會漏掉日志這個關(guān)鍵因素,導(dǎo)致功能在使用的時候出錯卻無法溯源。 其實(shí),只需要寫一個非常簡單日志裝飾,我們就能大大提升排
    的頭像 發(fā)表于 10-31 15:05 ?528次閱讀
    <b class='flag-5'>Python</b> <b class='flag-5'>自制</b><b class='flag-5'>簡單</b>實(shí)用的<b class='flag-5'>日志</b><b class='flag-5'>裝飾</b><b class='flag-5'>器</b>

    如何寫一個簡單裝飾

    今天介紹的是一個已經(jīng)存在十三年,但是依舊不紅的庫 decorator,好像很少有人知道他的存在一樣。 這個庫可以幫你做什么呢 ? 其實(shí)很簡單,就是可以幫你更方便地寫python裝飾
    的頭像 發(fā)表于 11-01 09:54 ?533次閱讀
    如何寫一個<b class='flag-5'>簡單</b>的<b class='flag-5'>裝飾</b><b class='flag-5'>器</b>

    【每天學(xué)點(diǎn)AI】一個例子帶你了解Python裝飾到底在干嘛!

    今天我們來聊聊一種能給你的代碼變得“加料”的神器——Python裝飾。就像一杯咖啡,原本它是苦的,為了讓它符合我的口味,我給它添加了糖,添加之后就完美的符合了我的口味。那么,裝飾
    的頭像 發(fā)表于 09-20 16:54 ?596次閱讀
    【每天學(xué)點(diǎn)AI】一個例子帶你了解<b class='flag-5'>Python</b><b class='flag-5'>裝飾</b><b class='flag-5'>器</b>到底在干嘛!
    主站蜘蛛池模板: 国产精品美女一级在线观看 | 久久夜夜操 | 亚洲精品二区中文字幕 | 亚洲婷婷综合网 | 欧美极品在线视频 | 国产一区二区在线观看免费 | 欧美资源在线观看 | 免费播放欧美毛片欧美aaaaa | 天天在线天天看成人免费视频 | 日本视频一区在线观看免费 | 中文一区二区在线观看 | 日本一区不卡在线观看 | 五月天婷婷免费观看视频在线 | 天堂网www在线 | 亚洲欧洲精品成人久久曰影片 | 午夜资源在线 | 国产人人看 | 天堂在线中文无弹窗全文阅读 | 免费jyzzjyzz在线播放大全 | 欧美在线视频一区二区三区 | 四虎sihu新版影院亚洲精品 | 亚洲伊人成人 | 免费看特级淫片日本 | 久久精品国产99久久72 | 婷婷深爱五月 | 欧美性天天影视 | 免费黄色福利 | 老色99久久九九精品尤物 | 久久久久久国产精品免费 | 人人干人人澡 | 欧美日韩视频综合一区无弹窗 | 伊人网视频在线 | 51精品国产 | 夜夜操夜夜骑 | 丁香狠狠色婷婷久久综合 | 色婷婷久久综合中文久久蜜桃 | 亚洲一区二区三区免费视频 | 午夜美女视频在线观看高清 | 一区二区三区视频在线 | 色综合久久久久综合99 | 四虎国产在线观看 |