日志功能 - 使用 conf 配置文件
配置文件:Logger.conf
工具类:LogUtil.py
测试类:testDemo.py
执行效果
配置文件:Logger.conf
定义日志的类型、级别、格式等信息。
[loggers]
# 定义了三种写日志的方式:logger_root、logger_example01、logger_example02
keys=root,example01,example02
[logger_root]
# 日志的颗粒度级别:critical > error > warning > info > debug
level=DEBUG
# 日志设置:设定了日志的格式、位置、级别等信息
handlers=hand01,hand02
[logger_example01]
handlers=hand01,hand02
# 日志格式名字
qualname=example01
propagate=0
[logger_example02]
handlers=hand01,hand03
qualname=example02
propagate=0
###############################################
[handlers]
# 日志的设置:3种
keys=hand01,hand02,hand03
[handler_hand01]
# 流模式:打印到屏幕上(标准输出,标准错误输出)
class=StreamHandler
# 日志级别
level=DEBUG
# 日志的格式
formatter=form01
# 标准错误输出
args=(sys.stderr,)
[handler_hand02]
# 日志打印到文件
class=FileHandler
level=DEBUG
formatter=form01
# 设定日志文件位置,a表示追加打印
args=('e:\\AutoTestLog.log', 'a')
[handler_hand03]
# 回滚日志打印
class=handlers.RotatingFileHandler
level=INFO
formatter=form01
args=('e:\\AutoTestLog.log', 'a', 10*1024*1024, 5)
# 10*1024*1024:一个日志文件最大是10m,最多打印5个文件
# 打印超过50mb的日志信息,那么会把第一个日志文件做覆盖写
###############################################
[formatters]
keys=form01,form02
# form01格式,设定每一行日志的格式信息
[formatter_form01]
format=%(asctime)s %(filename)s[line:%(lineno)d] 【%(levelname)s】 %(message)s
# %(asctime):时间
# %(filename):当前执行的文件名
# %(lineno):当前执行代码行号
# %(levelname):日志的级别
# %(message):具体的日志信息
# 日期格式:年-月-日 时-分-秒
datefmt=%Y-%m-%d %H:%M:%S
[formatter_form02]
format=%(name)-12s: %(levelname)-8s %(message)s
datefmt=%Y-%m-%d %H:%M:%S
常用配置说明:
format: 指定输出的格式和内容,format 可以输出很多有用信息,如下所示:
- %(levelno)s: 打印日志级别的数值
- %(levelname)s: 打印日志级别名称
- %(pathname)s: 打印当前执行程序的路径,其实就是sys.argv[0]
- %(filename)s: 打印当前执行程序名
- %(funcName)s: 打印日志的当前函数
- %(lineno)d: 打印日志的当前行号
- %(asctime)s: 打印日志的时间
- %(thread)d: 打印线程ID
- %(threadName)s: 打印线程名称
- %(process)d: 打印进程ID
- %(message)s: 打印日志信息
datefmt: 指定时间格式,同time.strftime()
level: 设置日志级别,默认为logging.WARNING
stream: 指定将日志的输出流,可以指定输出到sys.stderr,sys.stdout或者文件,默认输出到sys.stderr,当stream和filename同时指定时,stream被忽略
工具类:LogUtil.py
封装 4 种日志级别的函数。
1 import logging.config
2 import logging
3
4
5 # 写绝对路径和相对路径都可以
6 logging.config.fileConfig("Logger.conf")
7 logger = logging.getLogger("example01")
8
9 def debug(message):
10 # 打印debug级别的日志方法
11 logger.debug(message)
12
13 def warning(message):
14 # 打印warning级别的日志方法
15 logger.warning(message)
16
17 def info(message):
18 # 打印info级别的日志方法
19 logger.info(message)
20
21 def error(message):
22 # 打印error级别的日志方法
23 logger.error(message)
24
25
26 if __name__=="__main__":
27 debug("hi")
28 info("gloryroad")
29 warning("hello")
30 error("这是一个error日志")
测试类:testDemo.py
使用工具类进行测试。
1 from selenium import webdriver
2 from LogUtil import *
3
4
5 driver = webdriver.Chrome()
6 debug("============== 开始搜索测试 ==============")
7 url = "http://www.sogou.com"
8 debug("访问网址:http://www.sogou.com")
9 driver.get(url)
10 debug("定位搜索框")
11 driver.find_element_by_id("query").send_keys("hiphop")
12 info("在输入框中输入搜索关键字串“hiphop”" + driver.find_element_by_id("query").get_attribute("value"))
13 debug("单击搜索按钮")
14 driver.find_element_by_id("stb").click()
15 debug("关闭浏览器")
16 driver.quit()
17 debug("============== 搜索测试结束 ==============")
执行效果
屏幕及日志文件的打印内容:
2021-01-10 23:47:25 LogUtil.py[line:7] 【DEBUG】 ============== 开始搜索测试 ==============
2021-01-10 23:47:25 LogUtil.py[line:7] 【DEBUG】 访问网址:http://www.sogou.com
2021-01-10 23:47:27 LogUtil.py[line:7] 【DEBUG】 定位搜索框
2021-01-10 23:47:27 LogUtil.py[line:13] 【INFO】 在输入框中输入搜索关键字串“hiphop”hiphop
2021-01-10 23:47:27 LogUtil.py[line:7] 【DEBUG】 单击搜索按钮
2021-01-10 23:47:28 LogUtil.py[line:7] 【DEBUG】 关闭浏览器
2021-01-10 23:47:31 LogUtil.py[line:7] 【DEBUG】 ============== 搜索测试结束 ==============
遗留问题:文件名及行号仍然对应工具类。
日志功能 - 使用 conf 配置文件的更多相关文章
- Linux就这个范儿 第16章 谁都可以从头再来--从头开始编译一套Linux系统 nsswitch.conf配置文件
Linux就这个范儿 第16章 谁都可以从头再来--从头开始编译一套Linux系统 nsswitch.conf配置文件 朋友们,今天我对你们说,在此时此刻,我们虽然遭受种种困难和挫折,我仍然有一个梦 ...
- jboss7访问日志功能及使用goaccess工具分析
网络上虽然很多文章分别讲到jboss7的访问日志如何配置,goaccess工具怎么分析nginx/tomcat等日志.但将两者放在一起即“通过goaccess分析jboss访问日志”的倒是没搜索到. ...
- php.ini与php-fpm.conf配置文件的区别
php-fpm.conf是PHP-FPM特有的配置文件 php.ini是所以php模式中必须的配置文件 两者的区别是,php-fpm.conf是PHP-FPM进程管理器的配置文件,php.ini是PH ...
- Nginx服务编译安装、日志功能、状态模块及访问认证模式实操
系统环境 [root@web ~]# cat /etc/redhat-release CentOS release 6.9 (Final) [root@web ~]# uname -a Linux d ...
- Nginx(二)------nginx.conf 配置文件
上一篇博客我们将 nginx 安装在 /usr/local/nginx 目录下,其默认的配置文件都放在这个目录的 conf 目录下,而主配置文件 nginx.conf 也在其中,后续对 nginx 的 ...
- zabbix_server.conf、zabbix_agentd.conf配置文件详解
zabbix_server.conf配置文件详解 AlertScriptsPath 默认值:/usr/local/share/zabbix/alertscripts 说明:告警脚本目录 AllowRo ...
- php-fpm.conf配置文件中文说明详解及重要参数说明
摘自:https://www.jb51.net/article/148550.htm 感谢分享 php-fpm工作流程 php-fpm全名是PHP FastCGI进程管理器 php-fpm启动后会先读 ...
- Apache httpd.conf配置文件 2(Main server configuration)
### Section 2: 'Main' server configuration # # The directives in this section set up the values used ...
- nginx 日志功能详解
nginx 日志功能 在 nginx 中有两种日志: access_log:访问日志,通过访问日志可以获取用户的IP.请求处理的时间.浏览器信息等 error_log:错误日志,记录了访问出错的信息, ...
随机推荐
- ADT基础(一)—— List,Stack,and Queue
ADT基础(一)-- List,Stack,and Queue 1 List 表示 数组:易于search,难于insert和remove 链表:难于search,易于insert和remove // ...
- Python3.x 基础练习题100例(01-10)
练习01: 题目: 有四个数字:1.2.3.4,能组成多少个互不相同且无重复数字的三位数?各是多少? 分析: 可填在百位.十位.个位的数字都是1.2.3.4.组成所有的排列后再去 掉不满足条件的排列. ...
- DatePicker 多时间粒度选择器组件
使用方法: 在.vue文件引入 import ruiDatePicker from '@/components/rattenking-dtpicker/rattenking-dtpicker.vue' ...
- 180. 连续出现的数字 + MySql + 连续出现数字 + 多表联合查询
180. 连续出现的数字 LeetCode_MySql_180 题目描述 代码实现 # Write your MySQL query statement below select distinct t ...
- Chome 88如何正确隐藏 webdriver?
从 Chrome 88开始,它的 V8 引擎升级了,一些接口发生了改变. 使用 Selenium 调用 Chrome 的时候,只需要增加一个配置参数: chrome_options.add_argum ...
- JAVA_标识符、数据类型、变量
标识符和关键字 所有的标识符否应该以字母a ~ z和 A ~Z ,美元符($).下划线(_)开始. 首字符之后可以是字母a ~ z和 A ~Z ,美元符($).下划线(_)的任意字符组合. 注 ...
- 为什么要从 Linux 迁移到 BSD 4
为什么要从 Linux 迁移到 BSD 4 许可证问题 Linux GPL 许可证对开发者的要求比较严格,它是一种开源的反模式,因为它强制发布所有修改过的源代码,并且阻止其他开源项目的集成,例如 GP ...
- 2018.9.9 nowcoder 普及组第一场
2018.9.9 nowcoder 普及组第一场 C-括号 题目大意:一个只包含左右括号的字符串\(S\),希望删掉S中若干个字符,使得剩下的字符串是一个合法的括号串,有多少不同的方案. Soluti ...
- mybatis&plus系列------Mysql的JSON字段的读取和转换
mybatis&plus系列------Mysql的JSON字段的读取和转换 一. 背景 在平常的开发中,我们可能会有这样的需求: 业务数据在存储的时候,并不是以mysql中的varchar丶 ...
- golang float32/64转string
v := 3.1415926535 s1 := strconv.FormatFloat(v, 'E', -1, 32)//float32s2 := strconv.FormatFloat(v, 'E' ...