python解析robot framework的output.xml并生成html

一、用pyh模块解析stat结点数据(output.py

python 复制代码
#coding=utf-8

import 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.documentElement

total = 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.data
        list.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.data
        list.append(d)
        #print 'total:'+d['fail']+', '+d['pass']+', '+d['text']

    return list

def 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.data
        list.append(d)
        #print 'total:'+d['fail']+', '+d['pass']+', '+d['text']

    return list

二、pyh生成带表格的HTML(report.py

python 复制代码
在这里插入代码片#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')

报错

复制代码
for n, v in self.attributes.iteritems():
AttributeError: 'dict' object has no attribute 'iteritems'

python3去掉了 iteritem()方法,所以需要修改一下

相关推荐
工程师老罗14 分钟前
YoloV1数据集格式转换,VOC XML→YOLOv1张量
xml·人工智能·yolo
喵手1 小时前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控
2501_944934731 小时前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
helloworldandy1 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
肖永威2 小时前
macOS环境安装/卸载python实践笔记
笔记·python·macos
TechWJ3 小时前
PyPTO编程范式深度解读:让NPU开发像写Python一样简单
开发语言·python·cann·pypto
枷锁—sha3 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全
abluckyboy3 小时前
Java 实现求 n 的 n^n 次方的最后一位数字
java·python·算法
喵手3 小时前
Python爬虫实战:构建各地统计局数据发布板块的自动化索引爬虫(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集数据csv导出·采集各地统计局数据发布数据·统计局数据采集
天天爱吃肉82184 小时前
跟着创意天才周杰伦学新能源汽车研发测试!3年从工程师到领域专家的成长秘籍!
数据库·python·算法·分类·汽车