成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

python(logging )日志模塊學(xué)習(xí)

stonezhu / 630人閱讀

摘要:它的構(gòu)造函數(shù)是其中參數(shù)是一個文件對象。它的構(gòu)造函數(shù)是是文件名,必須指定一個文件名。用于指定日志文件的最大文件大小。它的構(gòu)造函數(shù)是其中參數(shù)和參數(shù)和具有相同的意義。表示時間間隔的單位,不區(qū)分大小寫??赡軟]有線程名。

0.前置說明

1.運行環(huán)境:Win7虛擬機、python2.7(anacoda版)

2.本文大部分內(nèi)容引用此參考文獻:http://my.oschina.net/leejun2005/blog/126713

1.基本元素說明:

Logger:用于輸出的日志的總對象

Handlers:用來指定log的輸出方式

Formatters:設(shè)置日志信息的結(jié)構(gòu)和內(nèi)容格式,默認(rèn)的時間格式為%Y-%m-%d %H:%M:%S

Filter:過濾器,用來過濾的輸出內(nèi)容(如:只輸出debug以上的內(nèi)容)

Logger 常用函數(shù)

LOG=logging.getLogger(”chat.gui”)

Logger.setLevel(lel):指定最低的日志級別,低于lel的級別將被忽略。debug是最低的內(nèi)置級別,critical為最高

Logger.addFilter(filt)、Logger.removeFilter(filt):添加或刪除指定的filter

Logger.addHandler(hdlr)、Logger.removeHandler(hdlr):增加或刪除指定的handler

Logger.debug()、Logger.info()、Logger.warning()、Logger.error()、Logger.critical():可以設(shè)置的日志級別

Logger.log("debug","This is a bug"):可以通過這個函數(shù)直接輸出內(nèi)容并選擇對應(yīng)的告警級別

內(nèi)置級別
名稱 對應(yīng)數(shù)字級別
NOTSET 0
DEBUG 10
INFO 20
WARNING 30
ERROR 40
CRITICAL 50
Handlers 1.常用函數(shù)

Handler.setLevel(lel):指定被處理的信息級別,低于lel級別的信息將被忽略

Handler.setFormatter():給這個handler選擇一個格式

Handler.addFilter(filt)、Handler.removeFilter(filt):新增或刪除一個filter對象

2.Handler種類

logging.StreamHandler
使用這個Handler可以向類似與sys.stdout或者sys.stderr的任何文件對象(file object)輸出信息。
它的構(gòu)造函數(shù)是:StreamHandler([strm])
其中strm參數(shù)是一個文件對象。
默認(rèn)是sys.stderr

logging.FileHandler
和StreamHandler類似,用于向一個文件輸出日志信息。不過FileHandler會幫你打開這個文件。
它的構(gòu)造函數(shù)是:FileHandler(filename[,mode])
filename是文件名,必須指定一個文件名。
mode是文件的打開方式。
默認(rèn)是’a",即添加到文件末尾。

logging.handlers.RotatingFileHandler
這個Handler類似于上面的FileHandler,但是它可以管理文件大小。當(dāng)文件達到一定大小之后,它會自動將當(dāng)前日志文件改名,然后創(chuàng)建一個新的同名日志文件繼續(xù)輸出。比如日志文件是chat.log。當(dāng)chat.log達到指定的大小之后,RotatingFileHandler自動把 文件改名為chat.log.1。不過,如果chat.log.1已經(jīng)存在,會先把chat.log.1重命名為chat.log.2。。。最后重新創(chuàng)建 chat.log,繼續(xù)輸出日志信息。
它的構(gòu)造函數(shù)是:RotatingFileHandler( filename[, mode[, maxBytes[, backupCount]]])
其中filename和mode兩個參數(shù)和FileHandler一樣。
maxBytes用于指定日志文件的最大文件大小。如果maxBytes為0,意味著日志文件可以無限大,這時上面描述的重命名過程就不會發(fā)生。
backupCount用于指定保留的備份文件的個數(shù)。比如,如果指定為2,當(dāng)上面描述的重命名過程發(fā)生時,原有的chat.log.2并不會被更名,而是被刪除。

logging.handlers.TimedRotatingFileHandler
這個Handler和RotatingFileHandler類似,不過,它沒有通過判斷文件大小來決定何時重新創(chuàng)建日志文件,而是間隔一定時間就 自動創(chuàng)建新的日志文件。重命名的過程與RotatingFileHandler類似,不過新的文件不是附加數(shù)字,而是當(dāng)前時間。它的構(gòu)造函數(shù)是:
TimedRotatingFileHandler( filename [,when [,interval [,backupCount]]])
其中filename參數(shù)和backupCount參數(shù)和RotatingFileHandler具有相同的意義。
interval是時間間隔。
when參數(shù)是一個字符串。表示時間間隔的單位,不區(qū)分大小寫。它有以下取值:
S 秒
M 分
H 小時
D 天
W 每星期(interval==0時代表星期一)
midnight 每天凌晨

logging.handlers.SocketHandler

logging.handlers.DatagramHandler
以上兩個Handler類似,都是將日志信息發(fā)送到網(wǎng)絡(luò)。不同的是前者使用TCP協(xié)議,后者使用UDP協(xié)議。它們的構(gòu)造函數(shù)是:
Handler(host, port)
其中host是主機名,port是端口名

logging.handlers.SysLogHandler

logging.handlers.NTEventLogHandler

logging.handlers.SMTPHandler

logging.handlers.MemoryHandler

logging.handlers.HTTPHandler

Formatters
參數(shù) 含義
%(name)s Logger的名字
%(levelno)s 數(shù)字形式的日志級別
%(levelname)s 文本形式的日志級別
%(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)前時間,用UNIX標(biāo)準(zhǔn)的表示時間的浮點數(shù)表示
%(relativeCreated)d 輸出日志信息時的,自Logger創(chuàng)建以 來的毫秒數(shù)
%(asctime)s 字符串形式的當(dāng)前時間。默認(rèn)格式是 “2003-07-08 16:49:45,896”。逗號后面的是毫秒
%(thread)d 線程ID??赡軟]有
%(threadName)s 線程名。可能沒有
%(process)d 進程ID??赡軟]有
%(message)s 用戶輸出的消息

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/37565.html

相關(guān)文章

  • Python Logging 日志記錄入門

    Python Logging原來真的遠比我想象的要復(fù)雜很多很多,學(xué)習(xí)路線堪比git。但是又繞不過去,alternatives又少,所以必須要予以重視,踏踏實實認(rèn)認(rèn)真真的來好好學(xué)學(xué)才行。 學(xué)習(xí)Logging的目的:簡單腳本還好,print足夠。但是稍微復(fù)雜點,哪怕是三四個文件加起來兩三百行代碼,調(diào)試也開始變復(fù)雜起來了。再加上如果是后臺長期運行的那種腳本,運行信息的調(diào)查更是復(fù)雜起來。一開始我還在各種查...

    fnngj 評論0 收藏0
  • 學(xué)習(xí) python logging(1): 基本用法

    摘要:簡介日志在編程中是十分重要,可以幫助我們跟蹤事件應(yīng)用的運行情況查問題統(tǒng)計數(shù)據(jù)等。在記錄日志時,通常表示某件事情的發(fā)生。基本使用直接打印運行之后看到的是因為默認(rèn)等級是所以是不會顯示的。 簡介 日志在編程中是十分重要,可以幫助我們跟蹤事件、應(yīng)用的運行情況、查問題、統(tǒng)計數(shù)據(jù)等。在記錄日志時,通常表示某件事情的發(fā)生。 python 中 logging 模塊提供記錄的基礎(chǔ)方法: debug, i...

    Donne 評論0 收藏0
  • 5分鐘教你學(xué)會Django系統(tǒng)錯誤監(jiān)控

    摘要:一監(jiān)控所有的請求如何實現(xiàn)系統(tǒng)監(jiān)控,自動發(fā)送錯誤日志的郵件呢只需配置配置文件即可。設(shè)置發(fā)送郵件配置信息郵件會發(fā)送到設(shè)定的郵件列表中。 showImg(https://segmentfault.com/img/remote/1460000015327475); 一、監(jiān)控所有的request請求 如何實現(xiàn)系統(tǒng)監(jiān)控,自動發(fā)送錯誤日志的郵件呢? 只需配置配置settings文件即可。 1.設(shè)置發(fā)...

    Aldous 評論0 收藏0
  • Django搭建個人博客:日志記錄

    摘要:每一條日志記錄也包含級別,代表對應(yīng)消息的嚴(yán)重程度。即格式化器,主要功能是確定最終輸出的形式和內(nèi)容。最好是日志能夠按自然天進行記錄和分割。 上一章學(xué)習(xí)了自動化測試,很好,現(xiàn)在我們可以絞盡腦汁寫出一份全面的測試,來保證代碼永遠健康了。 話雖如此,但是作為一個獨立開發(fā)者很難寫出真正全面的測試代碼。這是因為用戶在使用你的網(wǎng)站時可不會循規(guī)蹈矩,而是會以各種怪異的姿勢瀏覽網(wǎng)頁、上傳數(shù)據(jù)。但這也不是...

    Lowky 評論0 收藏0
  • Unity命令行模式,也能「日志實時輸出」

    摘要:類似這樣執(zhí)行打印最終輸出的日志要想在命令行模式工作的時候,查看它的編譯進度,霖哥一般會遠程跑進執(zhí)行編譯工作的機器,然后用命令,把它的日志實時輸出來嗯,這相當(dāng)?shù)牟豢茖W(xué)啊。我是霖哥,一個商學(xué)院畢業(yè)的程序員,一個游戲開發(fā)工程師。 showImg(https://segmentfault.com/img/remote/1460000008856262); 如果你使用過Unity命令行模式(ba...

    whjin 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<