鱼C论坛

 找回密码
 立即注册
查看: 1322|回复: 1

【python】logging 不会向指定文件写入

[复制链接]
发表于 2018-2-8 22:36:11 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
1. a.py 是一个GUI 界面  b.py是执行主程序,通过a.py 向GUI写入数据,然后传递到b.py执行,a.py有两个按钮键,stop,start。
start开始执行,stop终止本次程序的执行

2.目前遇到一个问题:

a.py中输入一些数据,点击start开始执行b.py,结果发现有些关键数据输错了,赶紧点击stop终止本次程序的执行。数据修正过来之后,再点击start执行。

结果发现,b.py中的日志还会向上一次执行时创建的文件中,写入,同时也会想第二次点击start创建的文件写入,为什么会向两个文件同时写入,这样影响效率 啊

关于日志创建部分代码如下:

                curTime = time.strftime('%Y-%m-%d', time.localtime(time.time()))

                logFilename = ipaddr_input + '_' + str(curTime) + '.txt'
                errlogFilename = ipaddr_input + '_' + str(curTime) + '_error.txt'
   
                logFilepath = os.path.join(os.getcwd(), 'Log\\' + logFilename)
                errlogFilepath = os.path.join(os.getcwd(), 'Log\\' + errlogFilename)
                logger = logging.getLogger('mylog')  
                logger.setLevel(logging.DEBUG)  
                #ch = logging.StreamHandler()  
                #ch.setLevel(logging.DEBUG)  
                fh = logging.FileHandler(logFilepath, 'a')
                fh.setLevel(logging.DEBUG)
                eh = logging.FileHandler(errlogFilepath, 'a')
                eh.setLevel(logging.ERROR)
   
                #logger.addHandler(ch)  
                logger.addHandler(fh)
                logger.addHandler(eh)
   
                error_formatter = logging.Formatter("[%(asctime)s] %(name)s:%(levelname)s: %(message)s")
                file_formatter = logging.Formatter("[%(asctime)s] %(name)s:%(levelname)s: %(message)s")  
                console_formatter = logging.Formatter("[%(asctime)s] %(name)s:%(levelname)s: %(message)s")
   
                #ch.setFormatter(console_formatter)  
                fh.setFormatter(file_formatter)
                eh.setFormatter(error_formatter)
   
                logger.info(25 * '*' + 'Started' + 25 * '*')
            
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-2-10 17:07:45 | 显示全部楼层
logging.getLogger() 对象默认root,全局唯一,该对象与之前的文件绑定,所以造成之后建立的文件无法写入log信息
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-12-27 22:02

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表