zoukankan      html  css  js  c++  java
  • python 自定义log模块

    1. 随便用用1
    import logging
    # logging.basicConfig(level=logging.ERROR, format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s:%(message)s')
    logging.basicConfig(level=logging.INFO, format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s:%(message)s')
    logger = logging.getLogger(__name__)
    
    logger.info('infor')
    logger.error('errof')
    
    1. 随便用用2
    ###############################################
    #### LOGGING CLASS SETTINGS (py25+, py30+) ####
    ###############################################
    import socket
    import glob
    import logging
    import logging.handlers
    import telnetlib
    import time
    
    Sus = 'succesfully'
    tn = telnetlib.Telnet('localhost','9999')
    print '...telnet pass'
    time.sleep(1)
    tn.write ('xxx')
    tn.read_until(Sus )
    tn.write ('quit\n')
    print '...quit\n'
    
    #f1 = logging.Formatter(fmt='%(levelname)s:%(name)s: %(message)s '
    #	'(%(asctime)s; %(filename)s:%(lineno)d)',
    #	datefmt="%Y-%m-%d %H:%M:%S")
    
    handlers = [
        logging.handlers.RotatingFileHandler('rotatedSyslog.log', maxBytes=10000000, backupCount=2),  #file_handler
        logging.StreamHandler()  #console_handler
    ]
    syslog_logger = logging.getLogger()
    syslog_logger.setLevel(logging.DEBUG)
    
    for h1 in handlers:
    #	h1.setFormatter(f1)
    	h1.setLevel(logging.DEBUG)
    	syslog_logger.addHandler(h1)
    	
    ##############################
    #### END LOGGING SETTINGS ####
    ##############################
    
    
    s = socket.socket(socket.AF_INET, socket.SOCK_DGRAM)
    s.bind(('', 8888))
    while True:
    	data, addr = s.recvfrom(2048)
    	data.rstrip('\x00')
    	syslog_logger.debug(data)
    #	print data
    	
    
    
    1. 定义 log.py
    import logging
    import logging.handlers
    
    LOG_FILENAME = 'jd-assistant.log'
    
    logger = logging.getLogger()
    
    def set_logger():
        logger.setLevel(logging.INFO)
        formatter = logging.Formatter('%(asctime)s %(levelname)s: %(message)s')
    
        console_handler = logging.StreamHandler()
        console_handler.setFormatter(formatter)
        logger.addHandler(console_handler)
    
        file_handler = logging.handlers.RotatingFileHandler(
            LOG_FILENAME, maxBytes=10485760, backupCount=5, encoding="utf-8")
        file_handler.setFormatter(formatter)
        logger.addHandler(file_handler)
    
    set_logger()
    
    1. 使用
    from log import logger
    
    class AsstException(Exception):
    
        def __init__(self, message):
            super().__init__(message)
            logger.error(message)
    
  • 相关阅读:
    UVALive2287 POJ1047 HDU1313 ZOJ1073 Round and Round We Go【大数+数学计算】
    HDU1559 最大子矩阵【DP】
    51Nod-1050 循环数组最大段和【最大子段和+最小子段和+DP】
    51Nod-1051 最大子矩阵和【最大子段和+DP】
    UVALive2288 POJ1050 HDU1081 ZOJ1074 To The Max【最大子段和+DP】
    UVALive2363 POJ1005 HDU1065 ZOJ1049 I Think I Need a Houseboat【数学计算】
    UVALive6050 Primes【素数筛选+前缀和】
    POJ3978 Primes【素数筛选+前缀和】
    sql里的多行多列转一行多列小技巧
    实体类作为另一个实体类的属性
  • 原文地址:https://www.cnblogs.com/amize/p/13766747.html
Copyright © 2011-2022 走看看