V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
kukuwhu
V2EX  ›  Python

Python 的 logging 全局对象疑问

  •  
  •   kukuwhu · 2015-05-13 11:48:46 +08:00 · 3217 次点击
    这是一个创建于 3488 天前的主题,其中的信息可能已经有所发展或是发生改变。
    我想在我的Python程序里加入debug打印机制替代print,采用的logging库,目前碰到的问题是当我初始化完一个全局logging对象时,比如:logger = logging.getLogger("myapp")
    我需要在每个函数里加上:global logger 才能使用logger.debug('xxx'),logger.error('xxxx') 等打印函数。

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

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

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

    程序入口对 root logger 进行初始化、设置格式、添加 handlers 等。
    weyou
        4
    weyou  
       2015-05-13 18:51:26 +08:00
    为什么每个函数都要加global logger? 一个都不要加!
    只要在每个需要log的文件开头logger = logging.getLogger("myapp") 就可以了
    neoblackcap
        5
    neoblackcap  
       2015-05-13 23:08:28 +08:00
    其实我时直接用logging的,然后用supervisor启动程序,随便将标准输出,标准错误输出重定向
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2099 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 22ms · UTC 00:35 · PVG 08:35 · LAX 16:35 · JFK 19:35
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.