亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

python操作日志的封裝方法(兩種方法)

 更新時間:2019年05月23日 14:38:19   作者:linux超  
這篇文章主要介紹了python操作日志的封裝方法,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值 ,需要的朋友可以參考下

前言

今天就簡單的對日志做個封裝,實際工作中直接拿去用吧

方法1

"""
------------------------------------
@Time : 2019/5/22 8:12
@Auth : linux超
@File : logfile.py
@IDE : PyCharm
@Motto: Real warriors,dare to face the bleak warning,dare to face the incisive error!
------------------------------------
"""
import logging
class Log(object):
 def __init__(self, name=__name__, path='mylog.log', level='DEBUG'):
  self.__name = name
  self.__path = path
  self.__level = level
  self.__logger = logging.getLogger(self.__name)
  self.__logger.setLevel(self.__level)
 def __ini_handler(self):
  """初始化handler"""
  stream_handler = logging.StreamHandler()
  file_handler = logging.FileHandler(self.__path, encoding='utf-8')
  return stream_handler, file_handler
 def __set_handler(self, stream_handler, file_handler, level='DEBUG'):
  """設置handler級別并添加到logger收集器"""
  stream_handler.setLevel(level)
  file_handler.setLevel(level)
  self.__logger.addHandler(stream_handler)
  self.__logger.addHandler(file_handler)
 def __set_formatter(self, stream_handler, file_handler):
  """設置日志輸出格式"""
  formatter = logging.Formatter('%(asctime)s-%(name)s-%(filename)s-[line:%(lineno)d]'
          '-%(levelname)s-[日志信息]: %(message)s',
          datefmt='%a, %d %b %Y %H:%M:%S')
  stream_handler.setFormatter(formatter)
  file_handler.setFormatter(formatter)
 def __close_handler(self, stream_handler, file_handler):
  """關閉handler"""
  stream_handler.close()
  file_handler.close()
 @property
 def Logger(self):
  """構造收集器,返回looger"""
  stream_handler, file_handler = self.__ini_handler()
  self.__set_handler(stream_handler, file_handler)
  self.__set_formatter(stream_handler, file_handler)
  self.__close_handler(stream_handler, file_handler)
  return self.__logger
if __name__ == '__main__':
 log = Log(__name__, 'file.log')
 logger = log.Logger
 logger.debug('I am a debug message')
 logger.info('I am a info message')
 logger.warning('I am a warning message')
 logger.error('I am a error message')
 logger.critical('I am a critical message')

初始化方法參數說明

name:自定義日志的名字, 默認是root, 但是我這里是使用調用文件的__name__ 作為默認名字

path:生成的日志的文件名

level:日志的級別,我這里把所有的級別都默認設置了level=DEBUG

方法2

使用logging.fileconfig這個模塊實現(不知道這個模塊的找度娘惡補一下把)

1.使用配置文件構造日志配置信息

logger.ini

[loggers]
keys = root, example01, example02
[logger_root]
level = DEBUG
handlers = hand01, hand02
[logger_example01]
handlers = hand01, hand02
qualname = example01
propagate = 0
[logger_example02]
handlers = hand01, hand03
qualname = example02
propagate = 0
[handlers]
keys = hand01, hand02, hand03
[handler_hand01]
class = StreamHandler
level = INFO
formatter = form01
args=(sys.stdout, )
[handler_hand02]
class = FileHandler
level = DEBUG
formatter = form01
args = ('log/test_case_log.log', 'a')
[handler_hand03]
class = handlers.RotatingFileHandler
level = INFO
formatter = form01
args = ('log/test_case_log.log', 'a', 10*1024*1024,3)
[formatters]
keys = form01, form02
[formatter_form01]
format = %(asctime)s-%(filename)s-[line:%(lineno)d]-%(levelname)s-[LogInfoMessage]: %(message)s
datefmt = %a, %d %b %Y %H:%M:%S
[formatter_form02]
format = %(name)-12s: %(levelname)-8s-[日志信息]: %(message)s
datefmt = %a, %d %b %Y %H:%M:%S

封裝python代碼

"""
------------------------------------
@Time : 2019/5/22 9:37
@Auth : linux超
@File : Log.py
@IDE : PyCharm
@Motto: Real warriors,dare to face the bleak warning,dare to face the incisive error!
------------------------------------
"""
import logging
from logging import config
class MyLog(object):
 def __init__(self):
  config.fileConfig('logger.ini')
  self.logger = logging.getLogger('example01')
 @property
 def my_logger(self):
  return self.logger
if __name__ == '__main__':
 log = MyLog()
 log.my_logger.info('it is my test log message info')

總結

兩種方法各有好處吧

第一種代碼很好理解思路清晰 , 但是不利于項目都維護,比如日志文件名,日志格式等無法修改,只能通過代碼內部修改

第二種其實是使用config模塊內部使用配置文件操作模塊ConfigParser做了封裝, 用配置文件來構造自定義日志器,好處很明顯,我們只要通過修改配置文件就能修改日志的格式,名字,級別等等一些設置,無需改動代碼,而且使用很簡單, 其實這種方法完全不需要封裝一個python代碼,哪個模塊需要輸出日志,直接調用config模塊獲得logger就可以了(就是上面文件的那幾行代碼),今天就到這吧......

以上所述是小編給大家介紹的python操作日志的封裝方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網站的支持!

相關文章

  • 尋找網站后臺地址的python腳本

    尋找網站后臺地址的python腳本

    這篇文章主要介紹了用python實現的尋找網站后臺地址的腳本代碼,國外牛人的作品,需要的朋友可以參考下
    2014-09-09
  • python實現知乎高顏值圖片爬取

    python實現知乎高顏值圖片爬取

    這篇文章主要介紹了python實現知乎高顏值圖片爬取,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下
    2019-08-08
  • python使用ddt過程中遇到的問題及解決方案【推薦】

    python使用ddt過程中遇到的問題及解決方案【推薦】

    在使用DDT數據驅動+HTMLTestRunner輸出測試報告時遇到過2個問題,沒個問題都很奇葩,下面小編通過本文給大家分享python使用ddt過程中遇到的問題及解決方案,需要的朋友參考下吧
    2018-10-10
  • 關于微信小程序爬蟲token自動更新問題

    關于微信小程序爬蟲token自動更新問題

    本文主要介紹了關于微信小程序爬蟲關于token自動更新問題,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-09-09
  • Python之列表實現棧的工作功能

    Python之列表實現棧的工作功能

    今天小編就為大家分享一篇關于Python之列表實現棧的工作功能,小編覺得內容挺不錯的,現在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-01-01
  • python networkx 包繪制復雜網絡關系圖的實現

    python networkx 包繪制復雜網絡關系圖的實現

    這篇文章主要介紹了python networkx 包繪制復雜網絡關系圖的實現,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-07-07
  • python break和continue用法對比

    python break和continue用法對比

    在本篇文章里小編給大家整理的是一篇關于python break和continue用法對比內容,有需要的朋友們可以學習參考下。
    2021-06-06
  • 基于Pandas讀取csv文件Error的總結

    基于Pandas讀取csv文件Error的總結

    今天小編就為大家分享一篇基于Pandas讀取csv文件Error的總結,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-06-06
  • python迭代dict的key和value的方法

    python迭代dict的key和value的方法

    今天小編就為大家分享一篇python迭代dict的key和value的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • 基于python3 pyQt5 QtDesignner實現窗口化猜數字游戲功能

    基于python3 pyQt5 QtDesignner實現窗口化猜數字游戲功能

    這篇文章主要介紹了基于python3 pyQt5 QtDesignner實現窗口化猜數字游戲功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-07-07

最新評論