忘记密码   免费注册 查看新帖 | 论坛精华区

ChinaUnix.net

  平台 论坛 博客 认证专区 大话IT HPC论坛 徽章 文库 沙龙 自测 下载 频道自动化运维 虚拟化 储存备份 C/C++ PHP MySQL 嵌入式 Linux系统
最近访问板块 发新帖
查看: 439 | 回复: 0

Python log问题 [复制链接]

论坛徽章:
0
发表于 2017-10-27 11:04 |显示全部楼层
scp
--Dev
--lib
--Math
----math.py
----__init__.py
--log
----log.py
----__init__.py
--stack
----Stack.py
----__init__.py
--sys
----sys.py
----__init__.py
--timer
----timer.py
----__init__.py

--run.py
我本意是想让所有的模块的log信息输出到同一个文件,如test.log文件中

如上所示的目录结构时,其他模块调用log模块,打印的log信息会输出到不同的文件里,我在log.py中设置的log名字是test.log,结果Stack.py的log文件变成了stacktest.log,timer的log文件为timertest.py ……
最终模块的log信息不是输出到同一个文件test.py里,而是输出到自己路径+test.log文件里。
只有把log.py文件放到run.py目录,即工程的根目录下才才会出现我期望的结果,所有log信息都放在test.log中。

那么问题来了,如上图目录,如何设置log.py中的信息,才能让所有的模块输出到同一个 log文件中

我的log.py:
#LOG_PATH = os.getcwd()
LOG_FILE = "SCPLog.log"
handler = logging.handlers.RotatingFileHandler(LOG_FILE, maxBytes = 1024*1024, backupCount = 5) # 实例化handler

fmt = '%(asctime)s - %(filename)s:%(lineno)s - %(name)s - %(message)s'

formatter = logging.Formatter(fmt) # 实例化formatter
handler.setFormatter(formatter) # 为handler添加formatter

logger = logging.getLogger('zihan') # 获取名为zihan的logger
logger.addHandler(handler) # 为logger添加handler
logger.setLevel(logging.DEBUG)

ALL = 100
SUCCESSFULLY = 1
UNSUCCESSFULLY = 0
UNFINISHED = -2
Scp_log = logger.debug
Scp_err = logger.error
您需要登录后才可以回帖 登录 | 注册

本版积分规则

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号 北京市公安局海淀分局网监中心备案编号:11010802020122
广播电视节目制作经营许可证(京) 字第1234号 中国互联网协会会员  联系我们:
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP