包和日志模块的使用

一、包

1.包就是一个保护有__init__.py文件的文件夹,包的本质就是一种模块,即包是用来导入使用的,包内部包含的文件也都是用来被导入使用的.包是为了更好组织好模块,就是一个文件夹.

注:在python2中,包下必须有一个__init__.py文件,而python3中即便没有也不会报错

首次导入包,会发生三件事

  1.以包下的__init__.py文件为基准来产生一个名称空间

  2.执行包下的__init__.py文件的代码,将执行过程中产生的名字都丢到名称空间中

  3.在当前执行文件中拿到一个名字p1,该p1就是指向__init__.py名称空间的

总结包的使用需要注意的地方:

  1.但凡是在导入语句中带点的,点的左边都必须是一个包

  2.导入包就是在导入包下的__init__.py文件

  3.如果使用绝对导入,绝对导入的起始位置都是以包的顶级目录为起始点

  4.但是包内部模块的导入通常应该使用相对导入,用"."代表当前所在的文件(而非执行文件),两个点代表上一级

  强调:

    1.相对导入只能包内部的模块之间互相导入使用

    2. ".."上一级不能超出顶级包

二、日志模块的使用

logging模块主要是用来记录日志信息的,需要注意的三点有,控制日志级别,控制日志格式,控制输出的目标为文件

等级:

  1.logging.debug("debug日志") #10

  2.logging.info("info日志") #20

  3.logging.warning("warning日志") #30

  4.logging.error("error日志") #40

  5.logging.critical("critical日志") #50

可在logging.basicConfig()函数中通过具体参数来更改logging模块默认行为,可用参数有
filename:用指定的文件名创建FiledHandler(后边会具体讲解handler的概念),这样日志会被存储在指定的文件中。
filemode:文件打开方式,在指定了filename时使用这个参数,默认值为“a”还可指定为“w”。
format:指定handler使用的日志显示格式。
datefmt:指定日期时间格式。
level:设置rootlogger(后边会讲解具体概念)的日志级别
stream:用指定的stream创建StreamHandler。可以指定输出到sys.stderr,sys.stdout或者文件,默认为sys.stderr。若同时列出了filename和stream两个参数,则stream参数会被忽略。

#格式
%(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:用户输出的消息

logging.basicConfig()

#======介绍
可在logging.basicConfig()函数中可通过具体参数来更改logging模块默认行为,可用参数有
filename:用指定的文件名创建FiledHandler(后边会具体讲解handler的概念),这样日志会被存储在指定的文件中。
filemode:文件打开方式,在指定了filename时使用这个参数,默认值为“a”还可指定为“w”。
format:指定handler使用的日志显示格式。
datefmt:指定日期时间格式。
level:设置rootlogger(后边会讲解具体概念)的日志级别
stream:用指定的stream创建StreamHandler。可以指定输出到sys.stderr,sys.stdout或者文件,默认为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用户输出的消息

#========使用
import logging
logging.basicConfig(filename=‘access.log‘,
                    format=‘%(asctime)s - %(name)s - %(levelname)s -%(module)s:  %(message)s‘,
                    datefmt=‘%Y-%m-%d %H:%M:%S %p‘,
                    level=10)

logging.debug(‘调试debug‘)
logging.info(‘消息info‘)
logging.warning(‘警告warn‘)
logging.error(‘错误error‘)
logging.critical(‘严重critical‘)

#========结果
access.log内容:
2017-07-28 20:32:17 PM - root - DEBUG -test:  调试debug
2017-07-28 20:32:17 PM - root - INFO -test:  消息info
2017-07-28 20:32:17 PM - root - WARNING -test:  警告warn
2017-07-28 20:32:17 PM - root - ERROR -test:  错误error
2017-07-28 20:32:17 PM - root - CRITICAL -test:  严重critical

part2: 可以为logging模块指定模块级的配置,即所有logger的配置

logging模块中的Formatter,Handler,Logger,Filter对象

#logger:产生日志的对象

#Filter:过滤日志的对象

#Handler:接收日志然后控制打印到不同的地方,FileHandler用来打印到文件中,StreamHandler用来打印到终端

#Formatter对象:可以定制不同的日志格式对象,然后绑定给不同的Handler对象使用,以此来控制不同的Handler的日志格式

logger是第一级过滤,然后才能到handler,我们可以给logger和handler同时设置level

import logging

# 1. logger对象: 负责生产各种级别的日志
logger1 = logging.getLogger(‘用户交易‘)  # 日志名用来标识日志的与什么业务有关

# 2. filter对象: 过滤日志

# 3. handler对象: 控制日志输出目标位置
fh1 = logging.FileHandler(‘a1.log‘,encoding=‘utf-8‘)
fh2 = logging.FileHandler(‘a2.log‘,encoding=‘utf-8‘)
ch = logging.StreamHandler()

# 4. formmater对象
formatter1 = logging.Formatter(
    fmt=‘%(asctime)s - %(name)s - %(levelname)s -%(module)s:  %(message)s‘,
    datefmt=‘%Y-%m-%d %H:%M:%S %p‘
)

formatter2 = logging.Formatter(
    fmt=‘%(asctime)s - %(levelname)s :  %(message)s‘,
    datefmt=‘%Y-%m-%d %H:%M:%S %p‘
)

# 5. 绑定logger对象与handler对象
logger1.addHandler(fh1)
logger1.addHandler(fh2)
logger1.addHandler(ch)

# 6. 绑定handler对象与formatter对象

fh1.setFormatter(formatter1)
fh2.setFormatter(formatter1)
ch.setFormatter(formatter2)

# 7. 设置日志级别,有logger对象与handler对象两层关卡,必须都放行最终日志才会放行,通常二者级别相同
logger1.setLevel(10)
fh1.setLevel(10)
fh2.setLevel(10)
ch.setLevel(10)

# 8. 使用logger对象产生日志
logger1.info(‘alex给egon转账1个亿‘)

应用:

settings.py

standard_format = ‘%(asctime)s - task:%(name)s - %(filename)s:%(lineno)d -‘                   ‘ %(levelname)s : [%(message)s]‘

simple_format = ‘%(filename)s:%(lineno)d - %(levelname)s : [%(message)s]‘

fh1_path = r‘a1.log‘
fh2_path = r‘a2.log‘

# log配置字典
LOGGING_DIC = {
    ‘version‘: 1,
    ‘disable_existing_loggers‘: False,
    ‘formatters‘: {
        ‘standard‘: {
            ‘format‘: standard_format
        },
        ‘simple‘: {
            ‘format‘: simple_format
        },
    },
    ‘filters‘: {},
    ‘handlers‘: {
        #打印到终端的日志
        ‘ch‘: {
            ‘level‘: ‘DEBUG‘,
            ‘class‘: ‘logging.StreamHandler‘,  # 打印到终端
            ‘formatter‘: ‘simple‘
        },
        #打印到a1.log文件的日志
        ‘fh1‘: {
            ‘level‘: ‘DEBUG‘,
            ‘class‘: ‘logging.FileHandler‘,  # 保存到文件
            ‘formatter‘: ‘standard‘,
            ‘filename‘: fh1_path,  # 日志文件的路径
            ‘encoding‘: ‘utf-8‘,  # 日志文件的编码,再也不用担心中文log乱码了
        },
        # 打印到a2.log文件的日志
        ‘fh2‘: {
            ‘level‘: ‘DEBUG‘,
            ‘class‘: ‘logging.FileHandler‘,  # 保存到文件
            ‘formatter‘: ‘simple‘,
            ‘filename‘: fh2_path,  # 日志文件的路径
            ‘encoding‘: ‘utf-8‘,  # 日志文件的编码,再也不用担心中文log乱码了
        },

    },
    ‘loggers‘: {
        ‘‘: {
            ‘handlers‘: [‘fh1‘, ‘fh2‘, ‘ch‘],
            ‘level‘: ‘DEBUG‘,
        },
    },
}

run.py

import logging.config
import settings

logging.config.dictConfig(settings.LOGGING_DIC)

logger1=logging.getLogger(‘用户交易‘)
#logger1-> fh1,fh2,ch
logger1.info(‘alex给egon转账1个亿‘)

logger2=logging.getLogger(‘用户权限‘)
#logger2-> fh1,fh2,ch
logger2.error(‘egon没有执行权限‘)

原文地址:https://www.cnblogs.com/Mister-JH/p/9457735.html

时间: 2024-10-09 14:25:02

包和日志模块的使用的相关文章

[Python] iupdatable包:日志模块使用介绍

一.说明 日志模块是对 logging 模块的单例封装 特点: 可同时向控制台和文件输出日志,并可选择关闭其中一种方式的输出: 集成colorlog,实现根据日志等级不同,控制台输出日志颜色不同: 灵活切换是否输出调试内容 二.简单示例 安装 iupdatable 包 pip install --upgrade iupdatable 使用实例: 1 from iupdatable.logging.Logger import Logger 2 from iupdatable.logging.Log

第五周日志模块正则和包

1.模块的使用 2.为什么要使用模块 1.从文件级别组织程序,更方便管理 2.引用别人写的,提升效率 3.如何实用模块 import spam 第一次导入模块发生几件事: 1.产生一个新的名称空间 2.运行原文件代码产生的名字都存放在1的名称空间中 运行过程中gloabl关键字指向改名称空间 当前文件的名称空间sapm 名称空间指向了spam.py运行文件的名称空间 def read1(): print(money) import spam import spam #重复导入时重复引用不是重新加

利用线程运行栈StackTraceElement设计Android日志模块

如果你想在你的Android程序中自动打印MainActivity.onCreate(line:37)这种类名.方法名(行数)的日志该如何实现呢? 1.引入Java的线程运行栈 Java.lang包中提供了StackTraceElement,可以用来获取方法的调用栈信息.通过调用线程函数Thread.currentThread().getStackTrace()可以获得StackTraceElement[]的堆栈数组,数组中保存了线程中的执行调用的方法.观察下面的代码: @Override pr

使用线程执行堆栈StackTraceElement设计Android日志模块

假设你想在你的Android自己主动打印程序MainActivity.onCreate(line:37)这样的类名.方法名称(行)登录如何实现? 1.介绍Java线程执行堆栈 Java.lang包中提供了StackTraceElement,能够用来获取方法的调用栈信息. 通过调用线程函数Thread.currentThread().getStackTrace()能够获得StackTraceElement[]的堆栈数组.数组中保存了线程中的运行调用的方法.观察以下的代码: @Override pr

ns3 Tutorial 中的日志模块(翻译)

转载地址:http://blog.sina.com.cn/s/blog_8ecca79b0101d7fe.html 1  日志模块的使用 在运行 first.cc 脚本时,我们已经简单了解了日志模块.现在,我们将更深入地了解日志子系统是为哪些用户案例设计的. 1.1 日志概述 很多大型系统支持某种消息记录功能,ns3 也不例外.在某些情况下,只有错误消息会被记录到操作控制台(在基于 Unix 的系统中通常是标准错误输出).在其他系统中,警告消息可能跟详细的信息消息一起被输出.在某些情况下,日志功

python模块部分----模块、包、常用模块

0.来源:https://www.cnblogs.com/jin-xin/articles/9987155.html 1.导入模块 1.1模块就是一个python文件,模块名是文件名 1.2导入模块的执行步骤: 先看有没有导入过,有的话不管,没有的话下一步 在sys.path中找到模块(除了内置Python的路径,还有当前执行文件路径) 创建新模块的命名空间,执行一遍模块代码,初始化模块 将模块导入进来 1.3import(导入模块) 直接导入整个模块,模块中的变量全部在他自己的命名空间中,不可

包与常用模块

一.包 1.什么是包? 它是一系列模块文件的结合体,表现形式就是一个文件夹, 该文件内部通常会有一个__init__.py文件,包的本质还是一个模块. 2.为何要使用包? 包的本质就是一个文件夹,那么文件夹唯一的功能就是将文件组织起来随着功能越写越多,我们无法将所以功能都放到一个文件中,于是我们使用模块去组织功能,而随着模块越来越多,我们就需要用文件夹将模块文件组织起来,以此来提高程序的结构性和可维护性. 3.首次导入包 先产生一个执行文件的名称空间 1.>创建包下下面的__init__.py文

函数知识点 1.包 2.hashlib模块 --- 摘要算法模块 3.logging模块 4.openpyxl模块 5.深浅拷贝 # 17

函数知识点1.包 1 # coding(编码系统):utf-8 2 """ 3 1.模块的三种来源: 4 1.内置 5 2.第三方 6 3.自定义 7 2.模块的四种表现形式: 8 1. .py文件 9 2.共享文件 10 3.包 11 4.内置 12 3.研究模块和包: 13 # 还可以站在另外两个角度分析: 14 1.模块的开发者 15 2.模块的使用者 16 4.导模块的那一瞬间发生了什么? 17 首先运行执行文件run.py,创建一个run.py的名称空间 18 1.

包、logging模块、hashlib加密模块、openpyxl模块、深浅拷贝

一.什么是包? 1.1包是一系列模块文件的总和,就是一个文件夹.该文件夹通常(python3和python的区别)会有一个init文件,包的本质还是一个模块 1.2具体的:包就是一个包含有__init__文件的文件夹,所以其实我们创建包的目的就是为了用文件夹将文件/模块组织起来 需要强调的是: 1. 在python3中,即使包下没有__init__.py文件,import 包仍然不会报错,而在python2中,包下一定要有该文件,否则import 包报错 2. 创建包的目的不是为了运行,而是被导