python實現的系統實用log類執行個體

來源:互聯網
上載者:User
本文執行個體講述了python實現的系統實用log類。分享給大家供大家參考。具體如下:

每個系統都必不可少會需要一個log類,方便瞭解系統的健全狀態和排錯,python本身已經提供了一個logger了,很強大,只要稍微封裝一下就可以放到自己的系統了,下面是我自己的log類

檔案名稱:logger.py

"""This module takes care of the logginglogger helps in creating a logging system for the application Logging is initialised by function LoggerInit."""import loggingimport osimport sysclass logger(object):  """Class provides methods to perform logging."""  m_logger = None  def __init__(self, opts, logfile):    """Set the default logging path."""    self.opts = opts    self.myname = 'dxscs'    self.logdir = '.'    self.logfile = logfile    self.filename = os.path.join(self.logdir, self.logfile)  def loginit(self):    """Calls function LoggerInit to start initialising the logging system."""    logdir = os.path.normpath(os.path.expanduser(self.logdir))    self.logfilename = os.path.normpath(os.path.expanduser(self.filename))    if not os.path.isdir(logdir):      try:        os.mkdir(logdir)      except OSError, e:        msg = ('(%s)'%e)        print msg        sys.exit(1)    self.logger_init(self.myname)  def logger_init(self, loggername):    """Initialise the logging system.    This includes logging to console and a file. By default, console prints    messages of level WARN and above and file prints level INFO and above.    In DEBUG mode (-D command line option) prints messages of level DEBUG    and above to both console and file.    Args:     loggername: String - Name of the application printed along with the log     message.    """    fileformat = '[%(asctime)s] %(name)s: [%(filename)s: %(lineno)d]: %(levelname)-8s: %(message)s'    logger.m_logger = logging.getLogger(loggername)    logger.m_logger.setLevel(logging.INFO)    self.console = logging.StreamHandler()    self.console.setLevel(logging.CRITICAL)    consformat = logging.Formatter(fileformat)    self.console.setFormatter(consformat)    self.filelog = logging.FileHandler(filename=self.logfilename, mode='w+')    self.filelog.setLevel(logging.INFO)    self.filelog.setFormatter(consformat)    logger.m_logger.addHandler(self.filelog)    logger.m_logger.addHandler(self.console)    if self.opts['debug'] == True:      self.console.setLevel(logging.DEBUG)      self.filelog.setLevel(logging.DEBUG)      logger.m_logger.setLevel(logging.DEBUG)    if not self.opts['nofork']:      self.console.setLevel(logging.WARN)  def logstop(self):    """Shutdown logging process."""    logging.shutdown()#test    if __name__ == '__main__':  #debug mode & not in daemon  opts = {'debug':True,'nofork':True}  log = logger(opts, 'dxscs_source.log')  log.loginit()  log.m_logger.info('hello,world')

執行結果:

終端和檔案中都顯示有:[2012-09-06 16:56:01,498] dxscs: [logger.py: 88]: INFO : hello,world

如果只需要顯示在檔案中可以將debug和nofork選項都置為false

希望本文所述對大家的Python程式設計有所協助。

  • 聯繫我們

    該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

    如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

    A Free Trial That Lets You Build Big!

    Start building with 50+ products and up to 12 months usage for Elastic Compute Service

    • Sales Support

      1 on 1 presale consultation

    • After-Sales Support

      24/7 Technical Support 6 Free Tickets per Quarter Faster Response

    • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.