中文字幕理论片,69视频免费在线观看,亚洲成人app,国产1级毛片,刘涛最大尺度戏视频,欧美亚洲美女视频,2021韩国美女仙女屋vip视频

打開APP
userphoto
未登錄

開通VIP,暢享免費(fèi)電子書等14項(xiàng)超值服

開通VIP
python的logging模塊【zz】
如果使用Python寫一個(gè)比較大型的程序,你一定會(huì)用上日志系統(tǒng)。特別是Python這樣的動(dòng)態(tài)語言,很多錯(cuò)誤都只能在運(yùn)行的時(shí)候才能發(fā)現(xiàn),一個(gè)好的日志系統(tǒng)對(duì)于Python程序相當(dāng)重要。最簡單的解決方案當(dāng)然是直接使用print輸出運(yùn)行信息。但是這樣太簡單了,沒有分級(jí)功能,如果在發(fā)布的時(shí)候想去掉調(diào)試用的運(yùn)行信息還得找出所有的print語句進(jìn)行修改。再者,print只能輸出到控制臺(tái),想要輸出到文件或者通過電子郵件發(fā)送到其他地方,一個(gè)print語句就沒辦法解決了。
通過使用Python的日志系統(tǒng),就可以解決以上問題。
首先看一下這個(gè)示例:
import logging
LOG=logging.getLogger(’應(yīng)用程序名’)
console = logging.StreamHandler()
console.setLevel(logging.INFO)
LOG.addHandler(console)
LOG.debug(’調(diào)試信息’)
LOG.info(’有用的信息’)
LOG.warning(’警告信息’)
LOG.error(’錯(cuò)誤信息’)
LOG.critical(’嚴(yán)重錯(cuò)誤信息’)
上面的代碼想控制臺(tái)輸出了五種錯(cuò)誤信息。分為五個(gè)從低到高的級(jí)別,從DEBUG到CRITICAL。此外,我們還指定了程序輸出的級(jí)別,只有INFO級(jí)別以上的信息才會(huì)被輸出。
這就是日志系統(tǒng)最常用的使用方法。這段代碼中有兩個(gè)概念可以幫助我們更進(jìn)一步使用Python的日志系統(tǒng):
1.        “Logger”。每個(gè)程序在輸出信息之前都要獲得一個(gè)Logger。Logger通常對(duì)應(yīng)了程序的模塊名,比如聊天工具的圖形界面模塊可以這樣獲得它的Logger:
LOG=logging.getLogger(”chat.gui”)
而核心模塊可以這樣:
LOG=logging.getLogger(”chat.kernel”)
我們接下來可以看到使用這種命名方法的用途。
2.        “Handler”。用于處理程序的輸出。Python的日志系統(tǒng)有多種Handler可以使用。有些Handler可以把信息輸出到控制臺(tái),有些Logger可以把信息輸出到文件,還有些Handler可以把信息發(fā)送到網(wǎng)絡(luò)上。如果覺得不夠用,還可以編寫自己的Handler。
所有的Handler可以支持三個(gè)操作:
1.      設(shè)置輸出格式。比如設(shè)置輸出的信息中包含時(shí)間和級(jí)別信息:
LOG=logging.getLogger(”chat.gui”)
console = logging.StreamHandler()
console.setLevel(logging.INFO)
formatter = logging.Formatter(’%(asctime)s %(levelname)s %(message)s’)
console.setFormatter(formatter)
LOG.addHandler(console)
熟悉Python的朋友應(yīng)該會(huì)發(fā)現(xiàn),logging.Formatter的參數(shù)實(shí)際上只是Python常用的“%”字符串格式化。它使用“%(name)s”表示占位符。下面是一個(gè)完整的表格,展示了日志系統(tǒng)可以輸出的各種信息:
%(name)s
Logger的名字
%(levelno)s
數(shù)字形式的日志級(jí)別
%(levelname)s
文本形式的日志級(jí)別
%(pathname)s
調(diào)用日志輸出函數(shù)的模塊的完整路徑名,可能沒有
%(filename)s
調(diào)用日志輸出函數(shù)的模塊的文件名
%(module)s
調(diào)用日志輸出函數(shù)的模塊名
%(funcName)s
調(diào)用日志輸出函數(shù)的函數(shù)名
%(lineno)d
調(diào)用日志輸出函數(shù)的語句所在的代碼行
%(created)f
當(dāng)前時(shí)間,用UNIX標(biāo)準(zhǔn)的表示時(shí)間的浮點(diǎn)數(shù)表示
%(relativeCreated)d
輸出日志信息時(shí)的,自Logger創(chuàng)建以來的毫秒數(shù)
%(asctime)s
字符串形式的當(dāng)前時(shí)間。默認(rèn)格式是“2003-07-08 16:49:45,896”。逗號(hào)后面的是毫秒
%(thread)d
線程ID??赡軟]有
%(threadName)s
線程名??赡軟]有
%(process)d
進(jìn)程ID??赡軟]有
%(message)s
用戶輸出的消息
2.      設(shè)置輸出級(jí)別
在上面我們已經(jīng)演示了如何設(shè)置輸出級(jí)別了。除了Python內(nèi)置的五種級(jí)別,我們還可以自定義輸出級(jí)別。
TODO 子定義輸出級(jí)別
3.      設(shè)置過濾器
細(xì)心的朋友一定會(huì)發(fā)現(xiàn)前文調(diào)用logging.getLogger()時(shí)參數(shù)的格式類似于“A.B.C”。采取這樣的格式其實(shí)就是為了可以配置過濾器。看一下這段代碼:
LOG=logging.getLogger(”chat.gui.statistic”)
console = logging.StreamHandler()
console.setLevel(logging.INFO)
formatter = logging.Formatter(’%(asctime)s %(levelname)s %(message)s’)
console.setFormatter(formatter)
filter=logging.Filter(”chat.gui”)
console.addFilter(filter)
LOG.addHandler(console)
和前面不同的是我們?cè)贖andler上添加了一個(gè)過濾器?,F(xiàn)在我們輸出日志信息的時(shí)候就會(huì)經(jīng)過過濾器的處理。名為“A.B”的過濾器只讓名字帶有“A.B”前綴的Logger輸出信息。可以添加多個(gè)過濾器,只要有一個(gè)過濾器拒絕,日志信息就不會(huì)被輸出。另外,在Logger中也可以添加過濾器。
每個(gè)Logger可以附加多個(gè)Handler。接下來我們就來介紹一些常用的Handler:
1)        logging.StreamHandler
使用這個(gè)Handler可以向類似與sys.stdout或者sys.stderr的任何文件對(duì)象(file object)輸出信息。它的構(gòu)造函數(shù)是:
StreamHandler([strm])
其中strm參數(shù)是一個(gè)文件對(duì)象。默認(rèn)是sys.stderr
2)    2.logging.FileHandler
和StreamHandler類似,用于向一個(gè)文件輸出日志信息。不過FileHandler會(huì)幫你打開這個(gè)文件。它的構(gòu)造函數(shù)是:
FileHandler(filename[,mode])
filename是文件名,必須指定一個(gè)文件名。
mode是文件的打開方式。參見Python內(nèi)置函數(shù)open()的用法。默認(rèn)是’a’,即添加到文件末尾。
3)    3.logging.handlers.RotatingFileHandler
這個(gè)Handler類似于上面的FileHandler,但是它可以管理文件大小。當(dāng)文件達(dá)到一定大小之后,它會(huì)自動(dòng)將當(dāng)前日志文件改名,然后創(chuàng)建一個(gè)新的同名日志文件繼續(xù)輸出。比如日志文件是chat.log。當(dāng)chat.log達(dá)到指定的大小之后,RotatingFileHandler自動(dòng)把文件改名為chat.log.1。不過,如果chat.log.1已經(jīng)存在,會(huì)先把chat.log.1重命名為chat.log.2。。。最后重新創(chuàng)建chat.log,繼續(xù)輸出日志信息。它的構(gòu)造函數(shù)是:
RotatingFileHandler( filename[, mode[, maxBytes[, backupCount]]])
其中filename和mode兩個(gè)參數(shù)和FileHandler一樣。
maxBytes用于指定日志文件的最大文件大小。如果maxBytes為0,意味著日志文件可以無限大,這時(shí)上面描述的重命名過程就不會(huì)發(fā)生。
backupCount用于指定保留的備份文件的個(gè)數(shù)。比如,如果指定為2,當(dāng)上面描述的重命名過程發(fā)生時(shí),原有的chat.log.2并不會(huì)被更名,而是被刪除。
4)    4.logging.handlers.TimedRotatingFileHandler
這個(gè)Handler和RotatingFileHandler類似,不過,它沒有通過判斷文件大小來決定何時(shí)重新創(chuàng)建日志文件,而是間隔一定時(shí)間就自動(dòng)創(chuàng)建新的日志文件。重命名的過程與RotatingFileHandler類似,不過新的文件不是附加數(shù)字,而是當(dāng)前時(shí)間。它的構(gòu)造函數(shù)是:
TimedRotatingFileHandler( filename [,when [,interval [,backupCount]]])
其中filename參數(shù)和backupCount參數(shù)和RotatingFileHandler具有相同的意義。
interval是時(shí)間間隔。
when參數(shù)是一個(gè)字符串。表示時(shí)間間隔的單位,不區(qū)分大小寫。它有以下取值:
S 秒
M 分
H 小時(shí)
D 天
W 每星期(interval==0時(shí)代表星期一)
midnight 每天凌晨
5)    5.logging.handlers.SocketHandler
6)    […]
6:00 PM | Read comments (1) | Permalink | python
python 日志打印[zz]
python 日志打印
發(fā)現(xiàn)python里面擴(kuò)展了日志打印功能。感覺比java自帶的還好,和log4j很類似。
下面總結(jié)下其用法。先說一種不用配置文件的:
<log.py>
1# -*- coding: gb2312 -*-
2import logging
3
4logging.basicConfig(level=logging.INFO,
5                    format='%(asctime)s %(name)-12s %(levelname)-8s %(message)s',
6                    datefmt='%m-%d %H:%M',
7                    filename='./AutoUpdate.log',
8                    filemode='w')
9
10console = logging.StreamHandler()
11console.setLevel(logging.INFO)
12formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
13console.setFormatter(formatter)
14logging.getLogger('').addHandler(console)
15
16
17##
18# console = logging.StreamHandler()
19# console = setLevel(logging.DEBUG)
20# formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
21# console.setFormatter(formatter)
22# logging.getLogger('').addHandler(console)
23
24
25def getLogging(name):
26 return logging.getLogger(name)
<test.py>
import log
testlog = log.getLogging('test')
testlog.error( "~~~~~~~~~~~~~~test1.")
testlog.info( "~~~~~~~~~~~~~~test2." )
testlog.exception( "~~~~~~~~~~~~~~~~~~~~~~~~~test3.")
用過log4j的人不會(huì)陌生這種用法。如果你對(duì)log4j有疑惑,或者想了解請(qǐng)?jiān)诒救薭log內(nèi)查找關(guān)于log4j的文章。有詳細(xì)介紹。這里不再贅述。
第二種使用配置文件的:
# logging.conf
[loggers]
keys=root,example
[handlers]
keys=consoleHandler,rotateFileHandler
[formatters]
keys=simpleFormatter
[formatter_simpleFormatter]
format=[%(asctime)s](%(levelname)s)%(name)s : %(message)s
[logger_root]
level=DEBUG
handlers=consoleHandler,rotateFileHandler
[logger_example]
level=DEBUG
handlers=consoleHandler,rotateFileHandler
qualname=example
propagate=0
[handler_consoleHandler]
class=StreamHandler
level=DEBUG
formatter=simpleFormatter
args=(sys.stdout,)
[handler_rotateFileHandler]
class=handlers.RotatingFileHandler
level=DEBUG
formatter=simpleFormatter
args=('test.log', 'a', 10000, 9)
<test2.py>
import logging
import logging.config
logging.config.fileConfig("logger.conf")
#create logger
logger = logging.getLogger("example")
#"application" code
logger.debug("debug message")
logger.info("info message")
logger.warn("warn message")
logger.error("error message")
logger.critical("critical message")
logHello = logging.getLogger("hello")
logHello.info("Hello world!")
其中值得注意的是args的含義。
5:59 PM | Read comments (3) | Permalink | python
使用Python的logging.config[zz]
使用Python的logging.config
Python的logging模塊接口仿log4j,概念上一致,使用上相當(dāng)方便。
利用logging.config.fileConfig(),可以將日志的配置用文件來描述,簡化了日志的初始化。
例程:
# test.py
import logging
import logging.config
logging.config.fileConfig("logging.conf")
#create logger
logger = logging.getLogger("example")
#"application" code
logger.debug("debug message")
logger.info("info message")
logger.warn("warn message")
logger.error("error message")
logger.critical("critical message")
logHello = logging.getLogger("hello")
logHello.info("Hello world!")
配置文件示例如下:
# logging.conf
[loggers]
keys=root,example
[handlers]
keys=consoleHandler,rotateFileHandler
[formatters]
keys=simpleFormatter
[formatter_simpleFormatter]
format=[%(asctime)s](%(levelname)s)%(name)s : %(message)s
[logger_root]
level=DEBUG
handlers=consoleHandler,rotateFileHandler
[logger_example]
level=DEBUG
handlers=consoleHandler,rotateFileHandler
qualname=example
propagate=0
[handler_consoleHandler]
class=StreamHandler
level=DEBUG
formatter=simpleFormatter
args=(sys.stdout,)
[handler_rotateFileHandler]
class=handlers.RotatingFileHandler
level=DEBUG
formatter=simpleFormatter
args=('test.log', 'a', 200000, 9)
注意,RotatingFileHandler中doRollover()會(huì)因?yàn)閞ename()出錯(cuò)而中途退出,造成日志文件沒有打開,并且后繼的日志消息都因?yàn)槿罩疚募]有打開而失敗??梢宰约涸趓ename()處加上try,或者不用RotatingFileHandler。估計(jì)隔一段時(shí)間就fileConfig()一次也是可以恢復(fù)正常。
詳見:Python logging RotatingFileHandler bug
該錯(cuò)誤僅當(dāng)日志文件滿時(shí)切換文件時(shí)才可能發(fā)生,當(dāng)文件被鎖定時(shí)才會(huì)出錯(cuò)。正常使用不會(huì)有問題,并且日志出錯(cuò)不會(huì)影響主程序的運(yùn)行。所以可以放心使用,想再可靠點(diǎn)就直接在源碼中加個(gè)try.
(轉(zhuǎn)載請(qǐng)注明來源于金慶的專欄)
本站僅提供存儲(chǔ)服務(wù),所有內(nèi)容均由用戶發(fā)布,如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊舉報(bào)
打開APP,閱讀全文并永久保存 查看更多類似文章
猜你喜歡
類似文章
django日志logging 的配置以及處理
[接口測試 - 基礎(chǔ)篇] 12 還是要掌握python日志管理模塊的
python 日志模塊 logging 詳解
使用python的logging模塊
Python日志庫logging總結(jié)
第10章:python自動(dòng)化——logging日志庫
更多類似文章 >>
生活服務(wù)
熱點(diǎn)新聞
分享 收藏 導(dǎo)長圖 關(guān)注 下載文章
綁定賬號(hào)成功
后續(xù)可登錄賬號(hào)暢享VIP特權(quán)!
如果VIP功能使用有故障,
可點(diǎn)擊這里聯(lián)系客服!

聯(lián)系客服