V2EX = way to explore
V2EX 是一个关于分享和探索的地方
Sign Up Now
For Existing Member  Sign In
推荐学习书目
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 · Mar 6, 2014 · 4176 views
    This topic created in 4438 days ago, the information mentioned may be changed or developed.
    如上,就是这个问题

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

    hack的话我可以xxx.logging = xxxx但是很不科学
    5 replies    1970-01-01 08:00:00 +08:00
    9hills
        1
    9hills  
       Mar 6, 2014 via iPad
    pyKun
        2
    pyKun  
    OP
       Mar 6, 2014
    @9hills

    我记得好像有个从命名空间入手的方法
    大概是
    module0的log不管
    module1和module1各种后代的log管
    mengzhuo
        3
    mengzhuo  
       Mar 7, 2014
    @pyKun 对的

    假设 __name__ 是 "foo.bar"

    这时候对loggers添加

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

    foo模块的logger就不会收到了
    pyKun
        4
    pyKun  
    OP
       Mar 7, 2014
    @mengzhuo

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

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

    thx
    chilaoqi
        5
    chilaoqi  
       Mar 7, 2014
    随便说下啊

    module_logger = logging.getLogger('requests')
    module_logger.setLevel(logging.ERROR)
    About   ·   Help   ·   Advertise   ·   Blog   ·   API   ·   FAQ   ·   Solana   ·   2463 Online   Highest 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 37ms · UTC 05:59 · PVG 13:59 · LAX 22:59 · JFK 01:59
    ♥ Do have faith in what you're doing.