配置文件: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 配置文件的更多相关文章

  1. Linux就这个范儿 第16章 谁都可以从头再来--从头开始编译一套Linux系统 nsswitch.conf配置文件

    Linux就这个范儿 第16章 谁都可以从头再来--从头开始编译一套Linux系统  nsswitch.conf配置文件 朋友们,今天我对你们说,在此时此刻,我们虽然遭受种种困难和挫折,我仍然有一个梦 ...

  2. jboss7访问日志功能及使用goaccess工具分析

    网络上虽然很多文章分别讲到jboss7的访问日志如何配置,goaccess工具怎么分析nginx/tomcat等日志.但将两者放在一起即“通过goaccess分析jboss访问日志”的倒是没搜索到. ...

  3. php.ini与php-fpm.conf配置文件的区别

    php-fpm.conf是PHP-FPM特有的配置文件 php.ini是所以php模式中必须的配置文件 两者的区别是,php-fpm.conf是PHP-FPM进程管理器的配置文件,php.ini是PH ...

  4. Nginx服务编译安装、日志功能、状态模块及访问认证模式实操

    系统环境 [root@web ~]# cat /etc/redhat-release CentOS release 6.9 (Final) [root@web ~]# uname -a Linux d ...

  5. Nginx(二)------nginx.conf 配置文件

    上一篇博客我们将 nginx 安装在 /usr/local/nginx 目录下,其默认的配置文件都放在这个目录的 conf 目录下,而主配置文件 nginx.conf 也在其中,后续对 nginx 的 ...

  6. zabbix_server.conf、zabbix_agentd.conf配置文件详解

    zabbix_server.conf配置文件详解 AlertScriptsPath 默认值:/usr/local/share/zabbix/alertscripts 说明:告警脚本目录 AllowRo ...

  7. php-fpm.conf配置文件中文说明详解及重要参数说明

    摘自:https://www.jb51.net/article/148550.htm 感谢分享 php-fpm工作流程 php-fpm全名是PHP FastCGI进程管理器 php-fpm启动后会先读 ...

  8. Apache httpd.conf配置文件 2(Main server configuration)

    ### Section 2: 'Main' server configuration # # The directives in this section set up the values used ...

  9. nginx 日志功能详解

    nginx 日志功能 在 nginx 中有两种日志: access_log:访问日志,通过访问日志可以获取用户的IP.请求处理的时间.浏览器信息等 error_log:错误日志,记录了访问出错的信息, ...

随机推荐

  1. TERSUS无代码开发(笔记03)-常用快捷键

    常用快捷键 1.a 普通行为元件调用 2.b 判断输入的值是什么值 3.c 有条件的传值处理 4.e 输出元件 5.f 传值或流程 6.t 输入元件 7.p 调用元件查询 8.x 判断是否有输入值 图 ...

  2. Vue学习笔记-Vue.js-2.X 学习(三)===>组件化高级

    (四) 组件化高级 1.插槽(slot)的基本使用 A:基本使用: <slot></slot> B:默认置:<slot><h1>中间可以放默认值< ...

  3. java高并发编程基础之AQS

    引言 曾经有一道比较比较经典的面试题"你能够说说java的并发包下面有哪些常见的类?"大多数人应该都可以说出 CountDownLatch.CyclicBarrier.Sempah ...

  4. 微信小程序:应用生命周期

    小程序的生命周期分为应用生命周期和页面生命周期. 应用指的是一个文件,是小程序的入口文件app.js,入口文件最外层方法名称是App,页面的js文件最外层是page,组件的js文件的最外层是compo ...

  5. 文字链接Link

    效果展示: 代码展示: <el-table-column label="引流扫码人数" align="center"> <template s ...

  6. CNN结构演变总结(一)经典模型

    导言:    自2012年AlexNet在ImageNet比赛上获得冠军,卷积神经网络逐渐取代传统算法成为了处理计算机视觉任务的核心.    在这几年,研究人员从提升特征提取能力,改进回传梯度更新效果 ...

  7. pytorch(05)计算图

    张量的一系列操作,增多,导致可能出现多个操作之间的串行并行,协同不同的底层之间的协作,避免操作的冗余.计算图就是为了解决这些问题产生的. 计算图与动态图机制 1. 计算图 计算图用来描述运算的有向无环 ...

  8. 优化自动化测试流程,使用 flask 开发一个 toy jenkins工具

    1.自动化 某一天你入职了一家高大上的科技公司,开心的做着软件测试的工作,每天点点点,下班就走,晚上陪女朋友玩王者,生活很惬意. 但是美好时光一般不长,这种生活很快被女主管打破.为了提升公司测试效率, ...

  9. Apache配置 3.域名跳转

    (1)介绍 当我们变更网站域名或者申多个域名指向一个网站的时候,这个时候我们就会用到域名跳转. (2)配 设置不是以111.com开头的网站都跳转到111.com上. 置 配置 设置不是以111.co ...

  10. uniCloud的简单使用 增删改查

    新建一个uni-app 项目 启动云开发 选择想要的云服务 在次之前先完成uniCloud 的实名认证 https://unicloud.dcloud.net.cn 有在Web控制台创建过云服务空间就 ...