Python 的 logging 全局对象疑问

2015-05-13 11:48:46 +08:00
 kukuwhu
我想在我的Python程序里加入debug打印机制替代print,采用的logging库,目前碰到的问题是当我初始化完一个全局logging对象时,比如:logger = logging.getLogger("myapp")
我需要在每个函数里加上:global logger 才能使用logger.debug('xxx'),logger.error('xxxx') 等打印函数。

如果优化可以使每个函数不加global logger? 参数传递的方式也不太好,每个函数都要加这么一个参数。。。

请教一下大家,谢谢!
3200 次点击
所在节点    Python
5 条回复
sunyanfei
2015-05-13 11:52:47 +08:00
每个函数都可以用 logger = logging.getLogger("myapp")吧,然后他们引用的都是同一个logger 对象
ksc010
2015-05-13 11:56:58 +08:00
若在同一个文件中 不用 global声明 也可以用
不同文件的话之在顶部 按照楼上说的 logger = logging.getLogger("myapp") 一次就行了
然后在下面的函数 直接引用 logger.debug('test')
Sylv
2015-05-13 17:30:11 +08:00
每个文件顶部:
import logging
logger = logging.getLogger("__name__")

然后文件内任何地方都能 logger.debug/info/warning/error,不用加 global。

程序入口对 root logger 进行初始化、设置格式、添加 handlers 等。
weyou
2015-05-13 18:51:26 +08:00
为什么每个函数都要加global logger? 一个都不要加!
只要在每个需要log的文件开头logger = logging.getLogger("myapp") 就可以了
neoblackcap
2015-05-13 23:08:28 +08:00
其实我时直接用logging的,然后用supervisor启动程序,随便将标准输出,标准错误输出重定向

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/190699

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX