内置的logging模块

#logging模块
import logging

#通过basicConfig方法设置日志格式,但这种只能在屏显和文件显示中选择其中一个
logging.basicConfig(         #设置日志的各种信息
    level=logging.DEBUG,      #设置级别最低为debug级别
    filename="logger.log",     #设置创建日志存放的文件
    filemode="w",               #设置日志填写的模式,默认下是追加模式 a ,设置“w“模式
    format="%(asctime)s %(filename)s [%(lineno)d] %(message)s"
    #format 参数,对日志的显示内容进行设置
)

# logging 的5中级别,下面级别从低到高
logging.debug("debug message")
logging.info("info message")
logging.warning("warning message")
logging.error("error message")
logging.critical("critical message")
"""
filename:用指定的文件名创建FiledHandler,这样日志会被存储在指定的文件中。
filemode:文件打开方式,在指定了filename时使用这个参数,默认值为“a”还可指定为“w”。
format:指定handler使用的日志显示格式。 
datefmt:指定日期时间格式。 
level:设置rootlogger(后边会讲解具体概念)的日志级别 
stream:用指定的stream创建StreamHandler。
    可以指定输出到sys.stderr,sys.stdout或者文件(f=open('test.log','w')),
    默认为sys.stderr。若同时列出了filename和stream两个参数,则stream参数会被忽略

format参数中可能用到的格式化串:
%(name)s      Logger的名字
%(levelno)s   数字形式的日志级别
%(levelname)s 文本形式的日志级别
%(pathname)s  调用日志输出函数的模块的完整路径名,可能没有
%(filename)s  调用日志输出函数的模块的文件名
%(module)s    调用日志输出函数的模块名
%(funcName)s  调用日志输出函数的函数名
%(lineno)d    调用日志输出函数的语句所在的代码行
%(created)f   当前时间,用UNIX标准的表示时间的浮 点数表示
%(relativeCreated)d 输出日志信息时的,自Logger创建以 来的毫秒数
%(asctime)s   字符串形式的当前时间。默认格式是 “2003-07-08 16:49:45,896”。逗号后面的是毫秒
%(thread)d    线程ID。可能没有
%(threadName)s 线程名。可能没有
%(process)d   进程ID。可能没有
%(message)s   用户输出的消息
"""
#设置一个logger,这个设置可以将它封装到一个函数内,使用时再调用

logger = logging.getLogger()             #建立一个日志对象
fh = logging.FileHandler("test.log")     #创建向文件发送的Handler
ch = logging.StreamHandler()           #创建向屏幕发送的Handler
fm = logging.Formatter("%(asctime)s %(message)s")  #设置日志显示格式
fh.setFormatter(fm)        #将格式传到文件
ch.setFormatter(fm)        #将格式传到屏显
logger.addHandler(fh)       #拿取文件显示的内容
logger.addHandler(ch)       #拿取屏显的内容
logger.setLevel("DEBUG")    #设置最低级别

#调用
logger.debug("hello")
logger.info("hello")
logger.warning("hello")
logger.error("hello")
logger.critical("hello")

"""
#如果创建两个logging对象,而这两个对象的根目录名是相同的,则后面创建的对象会覆盖上面创建的对象,
#这样无论前面是怎么设置的,都不会生效
logger1 = logging.getLogger("mylogger")
logger2 = logging.getLogger("mylogger")

#如果创建存在层级关系的对象,如下创建一个在根目录下的对象,再创建根下子目录下的对象
#则若logger运行,logger1会运行两次,因为他会从根开始运行,以此类推,只有上一级不运行,下一级才会只运行一次
logger = logging.getLogger()
logger1 = logging.getLogger("mylogger")
"""

 

posted @ 2019-05-18 12:10  saber゛  Views(199)  Comments(0Edit  收藏  举报