女人自慰AV免费观看内涵网,日韩国产剧情在线观看网址,神马电影网特片网,最新一级电影欧美,在线观看亚洲欧美日韩,黄色视频在线播放免费观看,ABO涨奶期羡澄,第一导航fulione,美女主播操b

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

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

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

Python自制簡單實用的日志裝飾器

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

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

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

1.簡陋版裝飾器

寫一個裝飾器非常簡單,因為本質(zhì)上裝飾器就是一個返回函數(shù)的“高階”函數(shù)而已:

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

圖片

用一下試試看:

圖片

效果如下:

圖片

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

2.普通版裝飾器

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

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

修改如下:

圖片

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

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

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

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

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

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)載。文章觀點僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。 舉報投訴
  • 字符串
    +關(guān)注

    關(guān)注

    1

    文章

    589

    瀏覽量

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

    關(guān)注

    3

    文章

    4367

    瀏覽量

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

    關(guān)注

    0

    文章

    142

    瀏覽量

    10808
  • python
    +關(guān)注

    關(guān)注

    56

    文章

    4823

    瀏覽量

    86070
收藏 人收藏

    評論

    相關(guān)推薦
    熱點推薦

    理解Python裝飾及其工作原理

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

    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 裝飾需要并行運行的函數(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 ?3485次閱讀
    一文讀懂<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 ?2051次閱讀

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

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

    Python裝飾的原理和案例

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

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

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

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

    電子發(fā)燒友網(wǎng)站提供《自制PCB花環(huán)裝飾圣誕樹.zip》資料免費下載
    發(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 ?895次閱讀

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

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

    Python 自制簡單實用的日志裝飾

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

    如何寫一個簡單裝飾

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

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

    今天我們來聊聊一種能給你的代碼變得“加料”的神器——Python裝飾。就像一杯咖啡,原本它是苦的,為了讓它符合我的口味,我給它添加了糖,添加之后就完美的符合了我的口味。那么,裝飾
    的頭像 發(fā)表于 09-20 16:54 ?717次閱讀
    【每天學(xué)點AI】一個例子帶你了解<b class='flag-5'>Python</b><b class='flag-5'>裝飾</b><b class='flag-5'>器</b>到底在干嘛!