記錄Python腳本的運行日志的方法
一、logging模塊
Python中有一個模塊logging,可以直接記錄日志
# 日志級別 # CRITICAL 50 # ERROR 40 # WARNING 30 # INFO 20 # DEBUG 10
logging.basicConfig()函數(shù)中的具體參數(shù):
filename: 指定的文件名創(chuàng)建FiledHandler,這樣日志會被存儲在指定的文件中;
filemode: 文件打開方式,在指定了filename時使用這個參數(shù),默認(rèn)值為“w”還可指定為“a”;
format: 指定handler使用的日志顯示格式;
datefmt: 指定日期時間格式。,格式參考strftime時間格式化(下文)
level: 設(shè)置rootlogger的日志級別
stream: 用指定的stream創(chuàng)建StreamHandler??梢灾付ㄝ敵龅絪ys.stderr,sys.stdout或者文件,默認(rèn)為sys.stderr。
若同時列出了filename和stream兩個參數(shù),則stream參數(shù)會被忽略。
format參數(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 |
用戶輸出的消息 |
二、logging模塊測試
1、打印日志到標(biāo)準(zhǔn)輸出中
import logging
logging.debug('debug message')
logging.info('info message')
logging.warning('warning message')
輸出結(jié)果
C:\Users\Administrator\AppData\Local\Programs\Python\Python36\python.exe D:/pyworkpeace/tupian.py 'https://www.tianyancha.com/login'
WARNING:root:warning messageProcess finished with exit code 0
可以看出默認(rèn)情況下Python的logging模塊將日志打印到了標(biāo)準(zhǔn)輸出中,且只顯示了大于等于WARNING級別的日志。默認(rèn)的日志的格式為:
日志級別:Logger名稱:用戶輸出消息
2、將日志文件輸入到文件中
import os
logging.basicConfig(filename=os.path.join(os.getcwd(),'log.txt'),level=logging.DEBUG)
logging.debug('this is a message')
運行這三行代碼后會在安裝Python的目錄中出現(xiàn)一個log.txt文件,文件內(nèi)容
DEBUG:root:this is a message
DEBUG:root:debug message
3、自定義格式,輸出日志文件
# -*-coding:utf-8-*-
import logging
def console_out(logFilename):
''''' Output log to file and console '''
# Define a Handler and set a format which output to file
logging.basicConfig(
level=logging.DEBUG, # 定義輸出到文件的log級別,大于此級別的都被輸出
format='%(asctime)s %(filename)s : %(levelname)s %(message)s', # 定義輸出log的格式
datefmt='%Y-%m-%d %A %H:%M:%S', # 時間
filename=logFilename, # log文件名
filemode='w') # 寫入模式“w”或“a”
# Define a Handler and set a format which output to console
console = logging.StreamHandler() # 定義console handler
console.setLevel(logging.INFO) # 定義該handler級別
formatter = logging.Formatter('%(asctime)s %(filename)s : %(levelname)s %(message)s') # 定義該handler格式
console.setFormatter(formatter)
# Create an instance
logging.getLogger().addHandler(console) # 實例化添加handler
# Print information # 輸出日志級別
logging.debug('logger debug message')
logging.info('logger info message')
logging.warning('logger warning message')
logging.error('logger error message')
logging.critical('logger critical message')
if __name__ == "__main__":
console_out('logging.log')
輸出結(jié)果:
此時也會自動生成一個日志文件,日志文件和運行文件在同一個文件夾中,文件名logging.log
2017-10-23 Monday 11:37:59 hgghf : DEBUG logger debug message
2017-10-23 Monday 11:37:59 hgghf : INFO logger info message
2017-10-23 Monday 11:37:59 hgghf : WARNING logger warning message
2017-10-23 Monday 11:37:59 hgghf : ERROR logger error message
2017-10-23 Monday 11:37:59 hgghf : CRITICAL logger critical message
修改輸出路徑:
filename='/tmp/test1.log', # log文件名
當(dāng)將腳本中這行代碼換一下,那么我們輸出日志的路徑地址就換成了D:\tmp
下面的方式同樣可以達到上述結(jié)果
4、自定義輸出位置
import logging
logging.basicConfig(level=logging.DEBUG,
format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
datefmt='%a, %d %b %Y %H:%M:%S',
filename='/tmp/test.log',
filemode='w')
logging.debug('debug message')
logging.info('info message')
logging.warning('warning message')
logging.error('error message')
logging.critical('critical message')
由于運行腳本放在D:\pyworkpeace\下,輸出文件在D盤tmp文件夾下test.log,內(nèi)容如下:
Mon, 23 Oct 2017 15:00:05 tupian.py[line:11] DEBUG debug message
Mon, 23 Oct 2017 15:00:05 tupian.py[line:12] INFO info message
Mon, 23 Oct 2017 15:00:05 tupian.py[line:13] WARNING warning message
Mon, 23 Oct 2017 15:00:05 tupian.py[line:14] ERROR error message
Mon, 23 Oct 2017 15:00:05 tupian.py[line:15] CRITICAL critical message
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Python常用數(shù)據(jù)庫接口sqlite3和MySQLdb學(xué)習(xí)指南
在本章節(jié)中,我們將學(xué)習(xí) Python 中常用的數(shù)據(jù)庫接口,包括 sqlite3用于SQLite數(shù)據(jù)庫和MySQLdb用于 MySQL 數(shù)據(jù)庫,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-06-06
Python基于identicon庫創(chuàng)建類似Github上用的頭像功能
這篇文章主要介紹了Python基于identicon庫創(chuàng)建類似Github上用的頭像功能,結(jié)合具體實例形式分析了identicon庫操作圖形的具體步驟與相關(guān)使用技巧,需要的朋友可以參考下2017-09-09
Python中實現(xiàn)文本預(yù)處理的方法小結(jié)
文本數(shù)據(jù)是數(shù)據(jù)科學(xué)和自然語言處理領(lǐng)域的關(guān)鍵組成部分,本文將深入探討Python中文本預(yù)處理的關(guān)鍵步驟,并提供豐富的示例代碼,希望對大家有所幫助2023-12-12
Python機器學(xué)習(xí)NLP自然語言處理基本操作之Seq2seq的用法
Seq2Seq模型是輸出的長度不確定時采用的模型,這種情況一般是在機器翻譯的任務(wù)中出現(xiàn),將一句中文翻譯成英文,那么這句英文的長度有可能會比中文短,也有可能會比中文長,所以輸出的長度就不確定了2021-10-10
解決Python?出現(xiàn)File?“<stdin>“,?line?1非語法錯誤的問題
這篇文章主要介紹了Python?出現(xiàn)File?“<stdin>“,?line?1非語法錯誤的解決辦法,本文給大家講解的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-03-03

