前言:

日常测试流程中,时常需要将测试结果输出为报告文档予以公示。而如果能够将报告文档生成的过程自动化实现,省去每次编辑表格、格式、图片的时间,无疑是一项可观的效率提升。

针对这一目标,小编了解并尝试了通过python中的docx模块进行word文档自动化生成,于此将其基本方法与实现过程同大家交流分享。

安装:

由于小编使用的是python3,实践过程中发现,如果直接使用pip命令安装模块:

pip install docx

import模块会因版本问题报错,应前往:https://www.lfd.uci.edu/~gohlke/pythonlibs/
下载最新的python_docx-0.8.10-py2.py3-none-any.whl再卸载原版本并重新安装此whl文件:

pip uninstall docx
pip install python_docx-0.8.10-py2.py3-none-any.wh

此时再次尝试import docx则不再有报错提示,即安装成功。

基本方法:

安装成功后,则可以开始着手根据格式、内容需求来生成文档,下面根据文档生成过程中的一些要素来介绍一些docx模块的基本方法。

首先是创建空白文档,其后的所有操作都需要基于文档对象document来进行操作:

from docx import Document
document = Document()

其次则是为文档添加标题、段落这样的基本元素:

document.add_heading('This is my title', 1)    #添加1级标题
document.add_paragragh('This is myparagragh')     #添加段落

但以此方式添加的标题、段落,其格式只能为docx模块默认格式且内容不易修改,实践中采取了一种更为灵活的方式:

head = document.add_heading(level=1)              #添加标题
run = head.add_run('This is my title')         #设置标题内容
para = document.add_paragraph()                   #添加段落
run = para.add_run('This is my paragragh')     #设置段落内容

由此,使用run对象进行内容追加,即可于后续直接对其字体等文字属性进行修改,例如:

run.font.name = fontName                           #设置英文字体
run._element.rPr.rFonts.set(qn('w:eastAsia'), fontName) #设置中文字体

而关于字号、加粗、颜色等其他属性的设置方式和字体设置类似,此处以一个集成函数为例:

from docx.shared import Inches, Pt, RGBColor, Cm
def fontSetup(run, fontName, size, bold=False, rgb=RGBColor(0,0,0)):run.font.name = fontNamerun._element.rPr.rFonts.set(qn('w:eastAsia'), fontName)if size and isinstance(size,Pt):run.font.size = size                # 设置字号大小,字体单位Ptif bold and bool(bold):run.bold = True                               # 设置文字加粗if rgb and isinstance(rgb, RGBColor):run.font.color.rgb = rgb                      # 设置文字颜色

同样的,也可以修改段落相关属性以契合预期表现效果:

from docx.enum.text import WD_ALIGN_PARAGRAPH
# 设置段落居中
para.paragraph_format.alignment = WD_ALIGN_PARAGRAPH.CENTER
# 设置段落首行缩进
para_section_contents.paragraph_format.first_line_indent = Inches(0.3)
# 段落设置无前后段间距、单倍行距
def paragraphSetup(para, space_before=Pt(0), space_after=Pt(0), line_spaceing=1):para.paragraph_format.space_before = space_beforepara.paragraph_format.space_after = space_afterpara.paragraph_format.line_spacing = line_spaceing

在完善了文档中文字、段落的格式之后,还需要针对测试报告中不可或缺的图片与表格进行添加与设置:

# 添加图片并居中,'pic.png'为相对路径,width为图片相对大小
para = document.add_paragraph()
para.paragraph_format.alignment = WD_ALIGN_PARAGRAPH.CENTER
run = para.add_run("")
run.add_picture("pic.png", width=Inches(5))
# 添加表格,rows和cols为行列数、Table Grid为实体边框样式
from docx.enum.table import WD_TABLE_ALIGNMENT
from docx.enum.table import WD_ALIGN_VERTICAL
from docx.enum.style import WD_STYLE_TYPE
table = document.add_table(rows=rows, cols=cols, style='Table Grid')
table.alignment = WD_TABLE_ALIGNMENT.CENTER            #表格居中
#  表格内容垂直、水平居中
table.cell(row,col).vertical_alignment= WD_ALIGN_VERTICAL.CENTER
table.cell(row,col).paragraphs[0].paragraph_format.alignment=WD_ALIGN_PARAGRAPH.CENTER

最后,考虑到文档的整体样式,可以对其页面进行设置:

#页面设置,A4,窄边距
def pageSetup(document):sec = document.sections[0]#边距page_distance = Inches(0.5)sec.left_margin = page_distancesec.right_margin = page_distancesec.top_margin = page_distancesec.bottom_margin = page_distance# A4sec.page_width =Inches(8.22)sec.page_height = Inches(11.65)

实现过程:

小编先来列举两个实现过程中的问题以作示例,继而对文档自动化生成的整体思路进行引申。

其一,报告内容中存在着多处需要加粗或改变字体的文字,那么如何便捷地适配每处文字的具体表现呢?此处的方案是先预设一些‘关键词’如:‘V5.1’、'高端机’等,再组成适配re.split()的正则表达式去对报告内容进行分割与设置:

# 根据预设关键词拼接正则表达式
bold_match = ''for bold_content in bold_contents:if bold_match:bold_match = bold_match + '|' + bold_contentelse:bold_match = bold_match + bold_content
bold_match = '(' + bold_match + ')'
# 分割段落文字
set_contents = re.split(bold_match, section_content)
split_contents = [x for x in set_contents if x]
# 根据分割情况设置不同的文字属性进行输出
for split_content in split_contents:run = para.add_run(split_content)if not split_content in bold_match:fontSetup(run, u'宋体', Pt(10.5))elif split_content.find('V') != -1:fontSetup(run, 'Calibri', Pt(10.5), True)else:fontSetup(run, u'宋体', Pt(10.5), True)

其二,考虑到表格着存在不同形式的合并需求,那么如何使其合并方式自动化地适配数据呢?此处的方案为在预设表格数据时,将合并的表格内数据重复写一次,即:

#表格数据——“评测项目”首行1-2列合并则写了2次、”对比产品“首列5-8行合并写了4次
table_data = {
"1stLine_1" : ["评测项目", "评测项目", "V5.XX.X内存占用", "V5.YY.Y内存占用"],
"2ndLine_2" : ["评测时间", "201X-XX-XX", "评测人员", "XXX"],
"3rdLine_3" : ["评测环境", "设备1", "设备信息", "Android 9.0.0\r(高端机)"],
"3rdLine_4" : ["评测环境", "设备2", "设备信息", "Android 5.1.1\r(中端机)"],
"4thLine_5" : ["对比产品", "竞品1", "产品版本", "X.X.X"],
"4thLine_6" : ["对比产品", "竞品2", "产品版本", "XX.X.X"],
"4thLine_7" : ["对比产品", "新版APP", "产品版本", "5.XX.X"],
"4thLine_8" : ["对比产品", "旧版APP", "产品版本", "5.YY.Y"]
}

其后于脚本的表格输出方法中,直接根据所读取到的重复数据项分布方式来决定表格的合并形式,如首行1-2列数据重复,则:

table.cell(0, 0).merge(table.cell(0, 1))

由以上两个问题进行举一反三,实际上整篇文档均是采取了预设数据、读取数据、输出数据这样的流程进行生成的,其中预设数据指的是:

而数据读取环节,则是去遍历content_data.items()中的内容,由此找到报告文档中每一小节中对应的预设内容,再去根据内容标识进行区分使用对应的方法进行数据输出:

总结:

综上,自动化测试报告生成脚本便完成了,在其后的版本迭代过程中只需更改预设数据中的内容,不同样式或内容的报告即可自动生成,希望本文能够对大家有所帮助

下面是配套资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!

最后: 可以在公众号:伤心的辣条 ! 免费领取一份216页软件测试工程师面试宝典文档资料。以及相对应的视频学习教程免费分享!,其中包括了有基础知识、Linux必备、Shell、互联网程序原理、Mysql数据库、抓包工具专题、接口测试工具、测试进阶-Python编程、Web自动化测试、APP自动化测试、接口自动化测试、测试高级持续集成、测试架构开发测试框架、性能测试、安全测试等。

学习不要孤军奋战,最好是能抱团取暖,相互成就一起成长,群众效应的效果是非常强大的,大家一起学习,一起打卡,会更有学习动力,也更能坚持下去。你可以加入我们的测试技术交流扣扣群:914172719(里面有各种软件测试资源和技术讨论)

喜欢软件测试的小伙伴们,如果我的博客对你有帮助、如果你喜欢我的博客内容,请 “点赞” “评论” “收藏” 一键三连哦!


好文推荐

转行面试,跳槽面试,软件测试人员都必须知道的这几种面试技巧!

面试经:一线城市搬砖!又面软件测试岗,5000就知足了…

面试官:工作三年,还来面初级测试?恐怕你的软件测试工程师的头衔要加双引号…

什么样的人适合从事软件测试工作?

那个准点下班的人,比我先升职了…

测试岗反复跳槽,跳着跳着就跳没了…

基于python的测试报告自动化生成相关推荐

  1. python自动化测试平台方案_基于Python的软件测试自动化平台研究

    基于 Python 的软件测试自动化平台研究 沈 啸 [摘 要] 摘要: 21 世纪是计算机和网络技术高速发展的时代,目前我国的软 件行业开发程度明显落后于欧美等发达国家,同时相对于开发工作而言,软件 ...

  2. sphinx:基于 Python 的文档生成工具

    sphinx:基于 Python 的文档生成工具 Motivation 对于软件开发来说,文档是软件可维护性的重要保障.sphinx 是一款文档生成工具,以 restructuredText 为标记语 ...

  3. 基于python的词云生成-中文词云(指定词云形状)

    基于python的词云生成(二) 1.简介    本文是在基于python的词云生成(一)的基础上,进一步对云词进行编写,本文还使用了jieba分词对中文进行分词处理,以做出更好的效果.    jie ...

  4. ShutIt:一个基于Python的shell自动化框架

    译者注:本文通过实例简单介绍了ShutIt这个基于Python的自动化框架的使用方法.除了pexpect,我们又多了这个选择.以下是译文. ShutIt是一个易于使用的基于shell的自动化框架.它对 ...

  5. 基于Python的特征自动化选择:两行代码完成特征工程

    本文介绍一个特征选择神器:特征选择器是用于减少机器学习数据集的维数的工具,可以傻瓜式地进行特征选择,两行代码即可搞定!! 来源:Will Koehrsen 代码整理及注释翻译:黄海广 代码和数据下载地 ...

  6. 两行代码完成特征工程-基于Python的特征自动化选择代码(提供下载)

    本文介绍一个特征选择神器:特征选择器是用于减少机器学习数据集的维数的工具,可以傻瓜式地进行特征选择,两行代码即可搞定!! 来源:Will Koehrsen 代码整理及注释翻译:黄海广 代码和数据下载地 ...

  7. 基于python技术的自动化运维是干嘛的_如何理解Python与自动化运维的关系。?

    一个是目的,一个是工具的关系 为了达到某个目的(比如这里的运维自动化),我们可以用不同的手段或者工具(比如这里的python) 如果你特别擅长Java.PHP,也可以用Java\PHP来开发相关运维自 ...

  8. 基于python技术的自动化运维是干嘛的_《Python自动化运维 技术与最佳实践》.pdf...

    [实例简介]Python自动化运维 技术与最佳实践 [刘天斯著][机械工业出版社][2014.12][291页].pdf [实例截图] [核心代码] 目 录 本书赞誉 前 言 第一部分 基础篇 第1章 ...

  9. 基于Python的接口自动化unittest测试框架和ddt数据驱动详解

    引言 在编写接口自动化用例时,我们一般针对一个接口建立一个.py文件,一条接口测试用例封装为一个函数(方法),但是在批量执行的过程中,如果其中一条出错,后面的用例就无法执行,还有在运行大量的接口测试用 ...

最新文章

  1. (转)access和SQL语句的区别
  2. IT兄弟连 JavaWeb教程 监听器3
  3. oracle10g cssd日志,【案例】Oracle CSSD进程HANG导致RAC节点重启原因分析笔记
  4. 卷积神经网络(CNN)新手指南 1
  5. win7 64位系统没有语音识别,该如何解决?
  6. 斗地主功能测试实战二之用例设计
  7. [最优化]凸集的定义与常见凸集
  8. Neural Network Intelligence (NNI) | 自动特征工程AutoFE示例程序
  9. 浏览器访问一个页面的步骤详解
  10. 顶尖学者介绍 | 抑郁领域研究Top1-5的大牛们都是谁?快来看!
  11. 网课答案搜题查询题库接口
  12. 论:程序员成就之天梯排行榜
  13. 在网页中打开本地应用程序exe
  14. 【AD封装】贴片铝电解系列封装(带3D)
  15. ipad 的android模拟器,iPad Simulator:免费Web版iPad模拟器
  16. Codeforces Round #597 (Div. 2) - BenFromHRBUST
  17. 无光驱情况下window XP系统安装盘使用nlite集成raid卡驱动
  18. JS、html中单引号与双引号的区别
  19. 手机录音转文字怎么才快速?1分钟学会这2个方法,一键语音转文字
  20. 计算机二级python题库试卷2

热门文章

  1. 947. 移除最多的同行或同列石头2021-01-23
  2. 专科学院计算机专业全国排名,2019年专科专业排行_2019世界大学排名 计算机专业...
  3. opengl linux windows,linux – 使用没有X-Window系统的OpenGL
  4. Android5手动root,魅蓝Note5如何获取ROOT权限?魅蓝Note5 ROOT教程(亲测可行)
  5. wincc怎么做数据库_关于WINCC通过PLCSIM来进行仿真中要怎么设置?
  6. 设置iis网页服务器cpu占比,asp.net-如何防止由于iis中的工作进程而导致CPU使用率100%...
  7. SetWindowPos()详解
  8. C++中INT与BYTE相互转换
  9. 【React性能优化】 redux优化
  10. Comparable和Comparator