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
pyKun
V2EX  ›  Python

logging 问题,我想收到自己代码里的 log,排除第三方模块里的 log

  •  1
     
  •   pyKun · 2014-03-06 23:23:03 +08:00 · 3577 次点击
    这是一个创建于 3907 天前的主题,其中的信息可能已经有所发展或是发生改变。
    如上,就是这个问题

    想从log的命名空间入手但思路没弄清楚

    hack的话我可以xxx.logging = xxxx但是很不科学
    5 条回复    1970-01-01 08:00:00 +08:00
    9hills
        1
    9hills  
       2014-03-06 23:27:04 +08:00 via iPad
    pyKun
        2
    pyKun  
    OP
       2014-03-06 23:39:16 +08:00
    @9hills

    我记得好像有个从命名空间入手的方法
    大概是
    module0的log不管
    module1和module1各种后代的log管
    mengzhuo
        3
    mengzhuo  
       2014-03-07 00:07:07 +08:00
    @pyKun 对的

    假设 __name__ 是 "foo.bar"

    这时候对loggers添加

    'foo.bar':{
    ....'level': 'DEBUG',
    ....'propagate': False, # 停止向上“冒泡”了
    },

    foo模块的logger就不会收到了
    pyKun
        4
    pyKun  
    OP
       2014-03-07 00:35:06 +08:00
    @mengzhuo

    思路对了,我这问题也解决了。

    有一段代码给运行时logging了各种设置,都设置到了None上了,也就是所有人的根,所以第三方的module的日志也出来了。所以我这里的要解决的时不要到None上,该到哪到哪了

    thx
    chilaoqi
        5
    chilaoqi  
       2014-03-07 10:45:06 +08:00
    随便说下啊

    module_logger = logging.getLogger('requests')
    module_logger.setLevel(logging.ERROR)
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2576 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 01:38 · PVG 09:38 · LAX 17:38 · JFK 20:38
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.