当前位置: 首页 > news >正文

饰品公司网站建设方案/广州企业网站建设

饰品公司网站建设方案,广州企业网站建设,国旅商旅app苹果免费下载,深圳建网站多少钱一年目录:导读 前言一、Python编程入门到精通二、接口自动化项目实战三、Web自动化项目实战四、App自动化项目实战五、一线大厂简历六、测试开发DevOps体系七、常用自动化测试工具八、JMeter性能测试九、总结(尾部小惊喜) 前言 1、日志级别 imp…

目录:导读

    • 前言
    • 一、Python编程入门到精通
    • 二、接口自动化项目实战
    • 三、Web自动化项目实战
    • 四、App自动化项目实战
    • 五、一线大厂简历
    • 六、测试开发DevOps体系
    • 七、常用自动化测试工具
    • 八、JMeter性能测试
    • 九、总结(尾部小惊喜)


前言

1、日志级别

import logging  # 引入logging模块# 将信息打印到控制台上
logging.debug(u"勇士")
logging.info(u"湖人")
logging.warning(u"太阳")
logging.error(u"雄鹿")
logging.critical(u"热火")

默认生成的root logger的level是logging.WARNING,低于该级别的就不输出了

级别排序:CRITICAL > ERROR > WARNING > INFO > DEBUG

debug : 打印全部的日志,详细的信息,通常只出现在诊断问题上
info : 打印info,warning,error,critical级别的日志,确认一切按预期运行
warning : 打印warning,error,critical级别的日志,一个迹象表明,一些意想不到的事情发生了,或表明一些问题在不久的将来(例如。磁盘空间低”),这个软件还能按预期工作
error : 打印error,critical级别的日志,更严重的问题,软件没能执行一些功能
critical : 打印critical级别,一个严重的错误,这表明程序本身可能无法继续运行

这时候,如果需要显示低于WARNING级别的内容,可以引入NOTSET级别来显示:

import logging  # 引入logging模块logging.basicConfig(level=logging.NOTSET)  # 设置日志级别
logging.debug(u"如果设置了日志级别为NOTSET,那么这里可以采取debug、info的级别的内容也可以显示在控制台上了")

2、分析解释

Logging.Formatter:这个类配置了日志的格式,在里面自定义设置日期和时间,输出日志的时候将会按照设置的格式显示内容。

Logging.Logger:Logger是Logging模块的主体。
进行以下三项工作:
为程序提供记录日志的接口;
判断日志所处级别,并判断是否要过滤;
根据其日志级别将该条日志分发给不同handler;

常用函数有:
Logger.setLevel() 设置日志级别;
Logger.addHandler() 和 Logger.removeHandler() 添加和删除一个Handler;
Logger.addFilter() 添加一个Filter,过滤作用;
Logging.Handler:Handler基于日志级别对日志进行分发,如设置为WARNING
级别的Handler只会处理WARNING及以上级别的日志。

常用函数有:
setLevel() 设置级别;
setFormatter() 设置Formatter;

3、日志输出-控制台

import logging  # 引入logging模块logging.basicConfig(level=logging.DEBUG,format='%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s')  # logging.basicConfig函数对日志的输出格式及方式做相关配置
# 由于日志基本配置中级别设置为DEBUG,所以一下打印信息将会全部显示在控制台上
logging.info('this is a loggging info message')
logging.debug('this is a loggging debug message')
logging.warning('this is loggging a warning message')
logging.error('this is an loggging error message')
logging.critical('this is a loggging critical message')

上面代码通过logging.basicConfig函数进行配置了日志级别和日志内容输出格式;
因为级别为DEBUG,所以会将DEBUG级别以上的信息都输出显示再控制台上。

4、日志输出-文件

import logging  # 引入logging模块
import os.path
import time# 第一步,创建一个logger
logger = logging.getLogger()
logger.setLevel(logging.INFO)  # Log等级总开关
# 第二步,创建一个handler,用于写入日志文件
rq = time.strftime('%Y%m%d%H%M', time.localtime(time.time()))
log_path = os.path.dirname(os.getcwd()) + '/Logs/'
log_name = log_path + rq + '.log'
logfile = log_name
fh = logging.FileHandler(logfile, mode='w')
fh.setLevel(logging.DEBUG)  # 输出到file的log等级的开关
# 第三步,定义handler的输出格式
formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
fh.setFormatter(formatter)
# 第四步,将logger添加到handler里面
logger.addHandler(fh)
# 日志
logger.debug('this is a logger debug message')
logger.info('this is a logger info message')
logger.warning('this is a logger warning message')
logger.error('this is a logger error message')
logger.critical('this is a logger critical message')

5、日志输出-控制台和文件

只要在输入到日志中的第二步和第三步插入一个handler输出到控制台:
创建一个handler,用于输出到控制台

ch = logging.StreamHandler()
ch.setLevel(logging.WARNING)  # 输出到console的log等级的开关

第四步和第五步分别加入以下代码即可

ch.setFormatter(formatter)
logger.addHandler(ch)

6、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: 打印日志信息

7、捕捉异常traceback记录

import os.path
import time
import logging# 创建一个logger
logger = logging.getLogger()
logger.setLevel(logging.INFO)  # Log等级总开关# 创建一个handler,用于写入日志文件
rq = time.strftime('%Y%m%d%H%M', time.localtime(time.time()))
log_path = os.path.dirname(os.getcwd()) + '/Logs/'
log_name = log_path + rq + '.log'
logfile = log_name
fh = logging.FileHandler(logfile, mode='w')
fh.setLevel(logging.DEBUG)  # 输出到file的log等级的开关# 定义handler的输出格式
formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
fh.setFormatter(formatter)
logger.addHandler(fh)
# 使用logger.XX来记录错误,这里的"error"可以根据所需要的级别进行修改
try:open('/path/to/does/not/exist', 'rb')
except (SystemExit, KeyboardInterrupt):raise
except Exception, e:logger.error('Failed to open file', exc_info=True)

如果需要将日志不上报错误,仅记录,可以写成exc_info=False

8、多模块调用logging,日志输出顺序

warning_output.py

import loggingdef write_warning():logging.warning(u"记录文件warning_output.py的日志")

error_output.py

import loggingdef write_error():logging.error(u"记录文件error_output.py的日志")

main.py

import logging
import warning_output
import error_outputdef write_critical():logging.critical(u"记录文件main.py的日志")warning_output.write_warning()  # 调用warning_output文件中write_warning方法
write_critical()
error_output.write_error()  # 调用error_output文件中write_error方法

9、日志滚动和过期删除(按时间)

# coding:utf-8
import logging
import time
import re
from logging.handlers import TimedRotatingFileHandler
from logging.handlers import RotatingFileHandlerdef backroll():#日志打印格式log_fmt = '%(asctime)s\tFile \"%(filename)s\",line %(lineno)s\t%(levelname)s: %(message)s'formatter = logging.Formatter(log_fmt)#创建TimedRotatingFileHandler对象log_file_handler = TimedRotatingFileHandler(filename="ds_update", when="M", interval=2, backupCount=2)#log_file_handler.suffix = "%Y-%m-%d_%H-%M.log"#log_file_handler.extMatch = re.compile(r"^\d{4}-\d{2}-\d{2}_\d{2}-\d{2}.log$")log_file_handler.setFormatter(formatter)logging.basicConfig(level=logging.INFO)log = logging.getLogger()log.addHandler(log_file_handler)#循环打印日志log_content = "test log"count = 0while count < 30:log.error(log_content)time.sleep(20)count = count + 1log.removeHandler(log_file_handler)if __name__ == "__main__":backroll()

说明:
filename:日志文件名的prefix;
when:是一个字符串,用于描述滚动周期的基本单位,字符串的值及意义如下:
“S”:Seconds
“M”:Minutes
“H”:Hours
“D”:Days
“W”:Week day (0=Monday)
“midnight”:Roll over at midnight
interva:滚动周期,单位有when指定,比如:when=’D’,interval=1,表示每天产生一个日志文件
backupCount:表示日志文件的保留个数

下面是我整理的2023年最全的软件测试工程师学习知识架构体系图

一、Python编程入门到精通

请添加图片描述

二、接口自动化项目实战

请添加图片描述

三、Web自动化项目实战

请添加图片描述

四、App自动化项目实战

请添加图片描述

五、一线大厂简历

请添加图片描述

六、测试开发DevOps体系

请添加图片描述

七、常用自动化测试工具

请添加图片描述

八、JMeter性能测试

请添加图片描述

九、总结(尾部小惊喜)

人生短暂,让我们活出自己的精彩。每一天都是新的开始,无论遇到多少挫折和困难,都要坚持不懈地奋斗,相信付出终将有回报。只要保持积极的心态和不屈不挠的精神,追求自己的梦想就一定会实现。

我们的时间有限,不要浪费在为别人而活的人生中。拥抱挑战,超越自我,为了自己想要的生活而奋斗!只有坚持不懈地努力,才能实现自己的梦想。相信自己,相信自己的能力,你一定能行!

只有不断奋斗,才能迎接更美好的未来;成功需要勇气、毅力和耐心,坚持不懈地努力,终将收获成果;每一天都是一个新的开始,要坚定信念,勇往直前,不断追求自己的梦想。

http://www.jmfq.cn/news/5265505.html

相关文章:

  • 他达拉非片和西地那非片的区别/seo单页快速排名
  • 全国住房和城乡建设委员会网站/站长工具怎么关掉
  • 环球国际网站建设/免费建立个人网站申请
  • 做网站一台电脑可以吗/亿驱动力竞价托管
  • 怎么做网站图片seo/广告文案经典范例200字
  • iis如何添加网站/实时新闻
  • 网站业务/新闻式软文
  • 建个购物网站/关键词调词平台
  • 做网站滚屏广告软件/爱站工具查询
  • 做网站必须要备案吗/新产品如何快速推广市场
  • 重庆市建设厅官塔吊证办理网站/画质优化app下载
  • 布吉网站建设哪家好/网络黄页推广软件哪个好用
  • 网友wordpress/朝阳区seo
  • 企业网站建设网站制作/郑州厉害的seo顾问
  • 宝安做棋牌网站建设哪家公司便宜/厦门seo小谢
  • 邪恶漫画网站源码/seo 推广教程
  • 有没有做任务能兑换现金的网站/镇江网站建设企业
  • 企业网站模板下载软件/域名注册需要什么条件
  • 大连做网站软件/google关键词搜索技巧
  • 在线网站软件免费下载/搜索引擎关键词排名
  • web2.0网站开发a》/网站定制开发
  • 网站建设服务公司案例/东莞网站营销推广
  • 电话用网站做综合布线/太原网站建设方案优化
  • 玉环做网站/百度指数查询官网入口登录
  • wordpress主题proland/关键词优化的发展趋势
  • 珠宝首饰商城网站建设/优化大师的三大功能
  • 网站后台排版布局/优化网哪个牌子好
  • 品牌开发公司排名/知了seo
  • 做网站找谁/竞价推广账户竞价托管公司
  • 北京智能网站建设平台/手机百度搜索引擎