欧美三区_成人在线免费观看视频_欧美极品少妇xxxxⅹ免费视频_a级毛片免费播放_鲁一鲁中文字幕久久_亚洲一级特黄

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

系統(tǒng) 1618 0

前言

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

方法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'):
  """設(shè)置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):
  """設(shè)置日志輸出格式"""
  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):
  """關(guān)閉handler"""
  stream_handler.close()
  file_handler.close()
 @property
 def Logger(self):
  """構(gòu)造收集器,返回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')
          

初始化方法參數(shù)說明

name:自定義日志的名字, 默認(rèn)是root, 但是我這里是使用調(diào)用文件的__name__ 作為默認(rèn)名字

path:生成的日志的文件名

level:日志的級別,我這里把所有的級別都默認(rèn)設(shè)置了level=DEBUG

方法2

使用logging.fileconfig這個模塊實(shí)現(xiàn)(不知道這個模塊的找度娘惡補(bǔ)一下把)

1.使用配置文件構(gòu)造日志配置信息

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')
          

總結(jié)

兩種方法各有好處吧

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

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

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


更多文章、技術(shù)交流、商務(wù)合作、聯(lián)系博主

微信掃碼或搜索:z360901061

微信掃一掃加我為好友

QQ號聯(lián)系: 360901061

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描下面二維碼支持博主2元、5元、10元、20元等您想捐的金額吧,狠狠點(diǎn)擊下面給點(diǎn)支持吧,站長非常感激您!手機(jī)微信長按不能支付解決辦法:請將微信支付二維碼保存到相冊,切換到微信,然后點(diǎn)擊微信右上角掃一掃功能,選擇支付二維碼完成支付。

【本文對您有幫助就好】

您的支持是博主寫作最大的動力,如果您喜歡我的文章,感覺我的文章對您有幫助,請用微信掃描上面二維碼支持博主2元、5元、10元、自定義金額等您想捐的金額吧,站長會非常 感謝您的哦!!!

發(fā)表我的評論
最新評論 總共0條評論
主站蜘蛛池模板: 欧美视频www | 天堂福利电影 | 亚洲人jizz日本人处 | 欧美成人免费全网站大片 | 538亚洲欧美国产日韩在线精品 | 日本大片在线免费观看 | 免费黄网站在线播放 | 一级电影免费 | 丝袜偷窥亚洲综合 | 成人片免费看 | 男女进进出出动态图啪啪 | 精品亚洲一区二区三区四区五区 | 亚洲zscs综合网站 | 久草在线视频资源站 | 免费成人在线网站 | 久久草在线看 | 排球少年第四季樱花动漫 | 九九视频只有精品六 | 亚洲欧洲精品成人久久奇米网 | 日韩精品一区二区三区 | 日本精品一区二区三区四区 | 99精品久久 | 小泽玛利亚一区二区 | 奇米色影| 国产免费又色又爽又黄的网站 | 日本妇人成熟免费不卡片 | 亚洲国产综合人成综合网站00 | 国产成人综合网 | 午夜家庭影院 | 亚洲国产中文字幕 | 国产片翁熄系列乱在线视频 | www操操| 欧美特黄一级视频 | 青青久热 | 99精品国产高清一区二区麻豆 | 天天干天天操天天爽 | 亚洲视频在线观看地址 | 欧美日韩性高爱潮视频 | 亚洲精品无码成人A片色欲 亚洲欧美日韩激情在线观看 | 久久精品蜜芽亚洲国产a | 欧美性色综合网 |