当前位置 博文首页 > 文章内容

    log输出到日志和控制台

    作者: 栏目:未分类 时间:2020-08-25 18:01:53

    本站于2023年9月4日。收到“大连君*****咨询有限公司”通知
    说我们IIS7站长博客,有一篇博文用了他们的图片。
    要求我们给他们一张图片6000元。要不然法院告我们

    为避免不必要的麻烦,IIS7站长博客,全站内容图片下架、并积极应诉
    博文内容全部不再显示,请需要相关资讯的站长朋友到必应搜索。谢谢!

    另祝:版权碰瓷诈骗团伙,早日弃暗投明。

    相关新闻:借版权之名、行诈骗之实,周某因犯诈骗罪被判处有期徒刑十一年六个月

    叹!百花齐放的时代,渐行渐远!



    新增Log类,输出日志到文件

    import os
    import logging

    PATH = lambda p: os.path.abspath(
    os.path.join(os.path.dirname(file), p)
    )

    class Log(object):
    """
    log类
    """
    def init(self):
    global logger, logPath, resultPath
    resultPath = PATH('../logs')
    # logPath = os.path.join(resultPath, time.strftime('%Y%m%d%H%M%S', time.localtime()))

        # if not os.path.exists(logPath):
        #     os.mkdir(logPath)
        if not os.path.exists(resultPath):
            os.mkdir(resultPath)
    
        # 创建logger,设置日志等级
        # DEBUG INFO WARNING ERROR CRITICAL等级依次递增
        self.logger = logging.getLogger()
        self.logger.setLevel(logging.INFO)
    
        # 创建handler,输出日志到文件
        # fh = logging.FileHandler(os.path.join(logPath, 'outPut.log'), encoding='utf-8', mode='a')
        fh = logging.FileHandler(os.path.join(resultPath, 'outPut.log'), encoding='utf-8', mode='a')
        formatter = logging.Formatter('%(asctime)s  - %(levelname)s - %(message)s')
        fh.setFormatter(formatter)
    
        # 创建handler,输出日志到terminal
        ch = logging.StreamHandler()
        formatter = logging.Formatter('%(asctime)s  - %(levelname)s - %(message)s')
        ch.setFormatter(formatter)
    
        if str(self.logger.handlers) == '[]':
            self.logger.addHandler(fh)
            self.logger.addHandler(ch)
        else:
            self.logger.info('log handler已存在')
    
        ch.close()
        fh.close()
    
    def getLogger(self):
        """
        get logger
        :return:
        """
        return self.logger
    

    if name == 'main':
    my_log = Log()
    my_log.logger.info('test info')