因为近期工作需要,常常要将测试结果/数据统计、汇总和展示,因此会有写静态HTML的需求,本文记录下python写静态HTML的小技巧
灵感时来源于unittest测试框架最常用的报告插件: HTMLTestRunner ,该插件本身基于python2且已经更新了,好在 @虫师 一直在维护和更新这个插件,使得它能继续被大家所使用,了解详情请移步: SeldomQA/HTMLTestRunner
回到HTMLTestRunner报告插件,阅读源码发现,作者只用了一个python文件便巧妙的将写HTML、页面绘制和数据嵌入搞定了。进一步分析可以看到,作者先是在Template基类中定义了测试报告的HTML结构模板和各个模块/表格模板,然后再以格式化输入的形式给每一个模板中填充目标数据,再将填充好的模板以格式化输入的形式填充到HTML结构模板中,最后再将所有内容写成一个HTML文件即可。
可以看到,这样的设计其实优点在于非常小巧和轻量,缺点在于可维护和可移植性差,数据量小还尚可,不太适合大量数据的统计和绘制。
这种设计的关键在于建模板,然后 按需 填充数据,最后再写HTML,通常我的做法是:
1、打开sublime text 3,新建一个PY文件。
2、因为涉及到系统文件路径的原因,我们这里先导入系统模块。
3、html = open("E:\\Download\\new\\new.html", "w")创建变量,然后设置文件名字,注意用w写方式来进行,这样就会创建一个新的HTML文件。
4、html.write("<!DOCtype HTML>\ \n<head><title>新的网页</title></head>\\n<body><h1>大家好啊</h1></body>")这个时候就可以写入相关的HTML代码了。
5、这个时候可以双击打开HTML文件,那么就可以看到书写的网页了。
lxml是处理XML和HTML的python语言,解析的时候,自动处理各种编码问题。而且它天生支持 XPath 1.0、XSLT 1.0、定制元素类。
安装:
HTML 实例
test, test.html指上述实例
获取 a 的所有标签, 这种html内容有多种写法,可以 直接得到了4个元素。
按照(2)中的方法,再加上 /@href ,可以直接得到属性值。
或者得到(2)中的结果,一一轮询。
更多表达式见 python xpath的学习
参考: https://www.jianshu.com/p/2ae6d51522c3
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)