已解决
python解析robot framework的output.xml并生成html
来自网友在路上 163863提问 提问时间:2023-10-23 07:24:22阅读次数: 63
最佳答案 问答题库638位专家为你答疑解惑
一、用pyh模块解析stat结点数据(output.py)
#coding=utf-8import xml.dom.minidom
import xml.etree.ElementTree#打开xml文档
dom = xml.dom.minidom.parse('./ui/output.xml');root2 = xml.etree.ElementTree.parse('./ui/output.xml')
#得到文档元素对象
root = dom.documentElementtotal = root.getElementsByTagName('total');
total_len = len(total)
tag = root.getElementsByTagName('tag');
tag_len = len(tag)
suite = root.getElementsByTagName('suite');
suite_len = len(suite)#total的stat节点个数
total2 = root2.getiterator("total")
total_stat_num = len(total2[total_len-1].getchildren())
#tag的stat节点个数
tag2 = root2.getiterator("tag")
tag_stat_num = len(tag2[tag_len-1].getchildren())
#suite的stat节点个数
suite2 = root2.getiterator("suite")
suite_stat_num = len(suite2[suite_len-1].getchildren())statlist = root.getElementsByTagName('stat');def get_total_statistics():list = []for i in range(0,total_stat_num):d = dict()d['fail'] = int(statlist[i].getAttribute("fail"))d['pass'] = int(statlist[i].getAttribute("pass"))d['total'] = d['fail']+d['pass']d['text'] = statlist[i].firstChild.datalist.append(d)#print 'total:'+d['fail']+', '+d['pass']+', '+d['text']return list
# list = get_total_statistics()
# print list
# print list[0]['fail']def get_statistics_by_tag():list = []for i in range(total_stat_num,total_stat_num+tag_stat_num):d = dict()d['fail'] = int(statlist[i].getAttribute("fail"))d['pass'] = int(statlist[i].getAttribute("pass"))d['total'] = d['fail']+d['pass']d['text'] = statlist[i].firstChild.datalist.append(d)#print 'total:'+d['fail']+', '+d['pass']+', '+d['text']return listdef get_statistics_by_suite():list = []for i in range(total_stat_num+tag_stat_num,len(statlist)):d = dict()d['fail'] = int(statlist[i].getAttribute("fail"))d['pass'] = int(statlist[i].getAttribute("pass"))d['total'] = d['fail']+d['pass']d['text'] = statlist[i].firstChild.datalist.append(d)#print 'total:'+d['fail']+', '+d['pass']+', '+d['text']return list
二、pyh生成带表格的HTML(report.py)
在这里插入代码片#coding=utf-8
from pyh import *
# from msilib.schema import Font
from fontTools.ttLib import TTFont
from output import *page = PyH('My wonderful PyH page')page << h2('Total statistics')value = get_total_statistics()
print(value) mytab = page << table(border='1')
mytr = mytab << tr()
mytr << th("Total Statistics",width="200",bgcolor="#CCFFCC")+th("total",width="100",bgcolor="#CCFFCC")+th("pass",width="100",bgcolor="#CCFFCC")+th("fail",width="100",bgcolor="#CCFFCC")
for i in range(len(value)):mytr = mytab << tr()mytr << td(value[i]['text'])+td(value[i]['total'])+td(value[i]['pass'])+td(value[i]['fail'])value = get_statistics_by_tag()
page << br()
mytab2 = page << table(border='1')
mytr = mytab2 << tr()
mytr << th("Statistics by Tag",width="200",bgcolor="#CCFFCC")+th("total",width="100",bgcolor="#CCFFCC")+th("pass",width="100",bgcolor="#CCFFCC")+th("fail",width="100",bgcolor="#CCFFCC")
for i in range(1,len(value)):mytr = mytab2 << tr()mytr << td(value[i]['text'])+td(value[i]['total'])+td(value[i]['pass'])+td(value[i]['fail'])value = get_statistics_by_suite()
page << br()
mytab3 = page << table(border='1')
mytr = mytab3 << tr()
mytr << th("Statistics by Suite",width="200",bgcolor="#CCFFCC")+th("total",width="100",bgcolor="#CCFFCC")+th("pass",width="100",bgcolor="#CCFFCC")+th("fail",width="100",bgcolor="#CCFFCC")
for i in range(1,len(value)):mytr = mytab3 << tr()mytr << td(value[i]['text'])+td(value[i]['total'])+td(value[i]['pass'])+td(value[i]['fail'])page.printOut('table.html')
查看全文
99%的人还看了
相似问题
- 〖大前端 - 基础入门三大核心之JS篇㊲〗- DOM改变元素节点的css样式、HTML属性
- Java 算法篇-链表的经典算法:判断回文链表、判断环链表与寻找环入口节点(“龟兔赛跑“算法实现)
- 代码随想录二刷 | 链表 | 删除链表的倒数第N个节点
- 节点导纳矩阵
- bhosts 显示节点 “unreach“ 状态
- 电子电器架构 —— 车载网关边缘节点总线转换
- 〖大前端 - 基础入门三大核心之JS篇㊳〗- DOM访问元素节点
- 第四天||24. 两两交换链表中的节点 ● 19.删除链表的倒数第N个节点 ● 面试题 02.07. 链表相交 ● 142.环形链表II
- CS224W5.1——消息传递和节点分类
- Vue报错解决Error in v-on handler: “Error: 无效的节点选择器:#div1“
猜你感兴趣
版权申明
本文"python解析robot framework的output.xml并生成html":http://eshow365.cn/6-22262-0.html 内容来自互联网,请自行判断内容的正确性。如有侵权请联系我们,立即删除!