⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 log_test21.py

📁 xen虚拟机源代码安装包
💻 PY
字号:
#!/usr/bin/env python## Copyright 2001-2002 by Vinay Sajip. All Rights Reserved.## Permission to use, copy, modify, and distribute this software and its# documentation for any purpose and without fee is hereby granted,# provided that the above copyright notice appear in all copies and that# both that copyright notice and this permission notice appear in# supporting documentation, and that the name of Vinay Sajip# not be used in advertising or publicity pertaining to distribution# of the software without specific, written prior permission.# VINAY SAJIP DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING# ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL# VINAY SAJIP BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR# ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER# IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT# OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.## This file is part of the Python logging distribution. See# http://www.red-dove.com/python_logging.html#"""Test harness for the logging module. Demonstrates the use of a wildcardname-space filter with and without custom message classes.Copyright (C) 2001-2002 Vinay Sajip. All Rights Reserved."""import logging, re, string, typesclass TaggedEvent:    def __init__(self, tag, msg):        self.tag = tag        self.msg = msg    def __str__(self):        return "%s: %s" % (self.tag, self.msg)class WildcardFilter(logging.Filter):    def __init__(self, wildcards):        self.setWildcards(wildcards)    def setWildcard(self, wildcard):        arr = string.split(wildcard, ".")        for i in xrange(len(arr)):            s = arr[i]            if s == "*":                arr[i] = r'[\w.]*'            elif string.find(s, "*") > 0:                arr[i] = string.replace(s, "*", r'[\w]*')        s = "^%s$" % string.join(arr, r'\.')        self.patterns.append(re.compile(s))    def setWildcards(self, wildcards):        if type(wildcards) != types.ListType:            wildcards = [wildcards]        self.patterns = []        for wildcard in wildcards:            self.setWildcard(wildcard)    def filter(self, record):        rv = 0        for pat in self.patterns:            m = pat.match(record.name)            if m is not None:                rv = 1                break        return rvclass TagFilter(WildcardFilter):    def filter(self, record):        rv = 0        if isinstance(record.msg, TaggedEvent):            tag = record.msg.tag        else:            tag = record.name        for pat in self.patterns:            m = pat.match(tag)            if m is not None:                rv = 1                break        return rvdef main():    handler = logging.StreamHandler()    root = logging.getLogger("")    root.setLevel(logging.DEBUG)    ab = logging.getLogger("a.b")    abc = logging.getLogger("a.b.c")    root.addHandler(handler)    filter = WildcardFilter("*.b")    handler.addFilter(filter)    ab.info("#1 from a.b")       #logged    abc.info("#1 from a.b.c")    #not logged    filter.setWildcards("*.b.c")    ab.info("#2 from a.b")       #not logged    abc.info("#2 from a.b.c")    #logged    filter.setWildcards("*.b*")    ab.info("#3 from a.b")       #logged    abc.info("#3 from a.b.c")    #not logged    filter.setWildcards("*")    ab.info("#4 from a.b")       #logged    abc.info("#4 from a.b.c")    #logged    filter.setWildcards("a*")    ab.info("#5 from a.b")       #not logged    abc.info("#5 from a.b.c")    #not logged    filter.setWildcards("a.*")    ab.info("#6 from a.b")       #logged    abc.info("#6 from a.b.c")    #logged    filter.setWildcards("*.b.*")    ab.info("#7 from a.b")       #not logged    abc.info("#7 from a.b.c")    #logged    filter.setWildcards(["*.b", "*.b.*"])    ab.info("#8 from a.b")       #logged    abc.info("#8 from a.b.c")    #logged    filter.setWildcards(["a.*.c"])    ab.info("#9 from a.b")       #not logged    abc.info("#9 from a.b.c")    #logged    #Now test filtering with a tagged class    handler.removeFilter(filter)    tagfilter = TagFilter(["*.b", "*.b.*"])    root.addFilter(tagfilter)    root.info(TaggedEvent("a.b", "#10"))     #logged    root.info(TaggedEvent("a.c", "#10"))     #not logged    root.info(TaggedEvent("a.b.c", "#10"))   #logged    root.info(TaggedEvent("a.b.d", "#10"))   #loggedif __name__ == "__main__":    import sys    args = sys.argv[1:]    if "-profile" in args:        import profile, pstats        args.remove("-profile")        statf = "log_test21.pro"        profile.run("main()", statf)        stats = pstats.Stats(statf)        stats.strip_dirs().sort_stats('time').print_stats()    else:        main()

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -