本文实例讲述了python实现的系统实用log类。分享给大家供大家参考。具体如下:
每个系统都必不可少会需要一个log类,方便了解系统的运行状况和排错,python本身已经提供了一个logger了,很强大,只要稍微封装一下就可以放到自己的系统了,下面是我自己的log类
文件名:logger.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
"""This module takes care of the logging logger helps in creating a logging system for the application Logging is initialised by function LoggerInit. """ import logging import os import sys class 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程序设计有所帮助。