久久精品国产亚洲高清|精品日韩中文乱码在线|亚洲va中文字幕无码久|伊人久久综合狼伊人久久|亚洲不卡av不卡一区二区|精品久久久久久久蜜臀AV|国产精品19久久久久久不卡|国产男女猛烈视频在线观看麻豆

千鋒教育-做有情懷、有良心、有品質(zhì)的職業(yè)教育機(jī)構(gòu)

手機(jī)站
千鋒教育

千鋒學(xué)習(xí)站 | 隨時(shí)隨地免費(fèi)學(xué)

千鋒教育

掃一掃進(jìn)入千鋒手機(jī)站

領(lǐng)取全套視頻
千鋒教育

關(guān)注千鋒學(xué)習(xí)站小程序
隨時(shí)隨地免費(fèi)學(xué)習(xí)課程

當(dāng)前位置:首頁(yè)  >  技術(shù)干貨  > Python 中 Logging 模塊使用詳情

Python 中 Logging 模塊使用詳情

來(lái)源:千鋒教育
發(fā)布人:xqq
時(shí)間: 2023-11-07 00:14:43 1699287283

1.為什么要用logging模塊

在實(shí)際應(yīng)用中,日志文件十分重要,通過(guò)日志文件,我們知道程序運(yùn)行的細(xì)節(jié);同時(shí),當(dāng)程序出問(wèn)題時(shí),我們也可以通過(guò)日志快速定位問(wèn)題所在。在我們寫程序時(shí),也可以借助logging模塊的輸出信息來(lái)調(diào)試代碼。

但是很多人還是在程序中使用print()函數(shù)來(lái)輸出一些信息,比如:

print'Startreadingdatabase'

records=model.read_recrods()

print'#records',records

print'Updatingrecord...'

model.update_records(records)

print'done'

這樣用的話缺點(diǎn)很明顯,當(dāng)程序?qū)懞眠\(yùn)行時(shí),我們要把這些print()函數(shù)刪掉,在簡(jiǎn)單的的程序中用還行,當(dāng)程序比較復(fù)雜時(shí),這個(gè)辦法很低效。

如果使用logging模塊,看看效果:

importlogging

logging.basicConfig(level=logging.INFO)

logger=logging.getLogger(__name__)

logger.info('Startreadingdatabase')

#readdatabasehere

records={'john':55,'tom':66}

logger.debug('Records:%s',records)

logger.info('Updatingrecords...')

#updaterecordshere

logger.info('Finishupdatingrecords')

運(yùn)行結(jié)果如下:

INFO:__main__:Startreadingdatabase

INFO:__main__:Updatingrecords...

INFO:__main__:Finishupdatingrecords

你也許會(huì)問(wèn),這和print()函數(shù)有什么區(qū)別呢?區(qū)別就在于,logging模塊可以通過(guò)改變level來(lái)控制一些語(yǔ)句是否被輸出,比如當(dāng)我們把level改成DEBUG級(jí)別:

logging.basicConfig(level=logging.DEBUG)

得到輸出如下:

INFO:__main__:Startreadingdatabase

DEBUG:__main__:Records:{'john':55,'tom':66}

INFO:__main__:Updatingrecords...

INFO:__main__:Finishupdatingrecords

2.logging模塊介紹

logging模塊是python自帶的一個(gè)包,因此在使用的時(shí)候,不必安裝,只需要import即可。有5個(gè)level,分別是debug,主要是查看一下程序運(yùn)行的信息,一般是調(diào)試程序要看的信息;info,是我們看程序是否如預(yù)料執(zhí)行的信息;warn,意料之外的,但是不影響程序運(yùn)行;error和critical就是一些比較嚴(yán)重的問(wèn)題,會(huì)影響程序運(yùn)行。默認(rèn)leval是warn,這個(gè)時(shí)候debug級(jí)別和info級(jí)別就不會(huì)被輸出到日志里了。如果想要看到這些信息,就需要進(jìn)行一些設(shè)置。

3.基礎(chǔ)設(shè)置

我們主要調(diào)用basicConfig(***kwargs*)這個(gè)函數(shù)對(duì)logging進(jìn)行設(shè)置。

常用的參數(shù)如下:

·level:主要調(diào)整logging的級(jí)別

·filename:輸出日志的路徑

·filemode:直接寫入還是追加寫入

·format:輸出的格式

我們通過(guò)調(diào)整format,可以輸出我們想要的格式,比如:

importlogging

logging.basicConfig(format='%(asctime)s-%(message)s',datefmt='%d-%b-%y%H:%M:%S')

logging.warning('Adminloggedout')

結(jié)果是:

12-Jul-1820:53:19-Adminloggedout

這就是在format參數(shù)中設(shè)置了時(shí)間的,所以得到了時(shí)間,我們可以輸出多種想要的信息

以上內(nèi)容為大家介紹了Python中Logging模塊使用詳情,希望對(duì)大家有所幫助,如果想要了解更多Python相關(guān)知識(shí),請(qǐng)關(guān)注IT培訓(xùn)機(jī)構(gòu):千鋒教育。http://m.2667701.com/

聲明:本站稿件版權(quán)均屬千鋒教育所有,未經(jīng)許可不得擅自轉(zhuǎn)載。
10年以上業(yè)內(nèi)強(qiáng)師集結(jié),手把手帶你蛻變精英
請(qǐng)您保持通訊暢通,專屬學(xué)習(xí)老師24小時(shí)內(nèi)將與您1V1溝通
免費(fèi)領(lǐng)取
今日已有369人領(lǐng)取成功
劉同學(xué) 138****2860 剛剛成功領(lǐng)取
王同學(xué) 131****2015 剛剛成功領(lǐng)取
張同學(xué) 133****4652 剛剛成功領(lǐng)取
李同學(xué) 135****8607 剛剛成功領(lǐng)取
楊同學(xué) 132****5667 剛剛成功領(lǐng)取
岳同學(xué) 134****6652 剛剛成功領(lǐng)取
梁同學(xué) 157****2950 剛剛成功領(lǐng)取
劉同學(xué) 189****1015 剛剛成功領(lǐng)取
張同學(xué) 155****4678 剛剛成功領(lǐng)取
鄒同學(xué) 139****2907 剛剛成功領(lǐng)取
董同學(xué) 138****2867 剛剛成功領(lǐng)取
周同學(xué) 136****3602 剛剛成功領(lǐng)取
相關(guān)推薦HOT
如何殺死一個(gè)Python線程

我經(jīng)常被問(wèn)到如何殺死一個(gè)后臺(tái)線程,這個(gè)問(wèn)題的答案讓很多人不開心:線程是殺不死的。在本文中,我將向您展示Python中用于終止線程的兩個(gè)選項(xiàng)。...詳情>>

2023-11-07 02:56:44
python的單元測(cè)試框架

1、AutotestAutotest是Google、Redhat、IBM公司聯(lián)合開發(fā)的分布式自動(dòng)化測(cè)試框架,兼顧軟硬件測(cè)試?;赑ython,用于操作系統(tǒng)內(nèi)核冒煙測(cè)試、服務(wù)...詳情>>

2023-11-07 02:17:07
數(shù)據(jù)科學(xué)領(lǐng)域Python比R語(yǔ)言更好

經(jīng)常有學(xué)員問(wèn)我們,在數(shù)據(jù)科學(xué)領(lǐng)域里,到底是該選Python呢,還是選R更好?誠(chéng)然,對(duì)于數(shù)據(jù)科學(xué)家來(lái)說(shuō),R和Python都很重要。但是對(duì)于一個(gè)新人數(shù)據(jù)...詳情>>

2023-11-07 01:37:31
Python中的'==' 和 'is'

==和is是Python對(duì)象比較中常用的兩種方式,==比較對(duì)象的值是否相等,is比較對(duì)象的身份標(biāo)識(shí)(ID)是否相等,是否是同一個(gè)對(duì)象,是否指向同一個(gè)內(nèi)存...詳情>>

2023-11-06 23:38:43
Python內(nèi)存分配

一、前言大多數(shù)編譯型語(yǔ)言,變量在使用前必須先聲明,其中C語(yǔ)言更加苛刻:變量聲明必須位于代碼塊最開始,且在任何其他語(yǔ)句之前。其他語(yǔ)言,想C...詳情>>

2023-11-06 22:33:55
快速通道