python循环写入html_Python写静态HTML

本文介绍了如何使用Python动态地创建HTML报告,灵感来源于HTMLTestRunner插件。通过定义HTML结构模板,然后填充数据,最后生成HTML文件。关键步骤包括提取HTML结构,用格式化输入替换动态部分,创建数据模板,组装数据并最终写入HTML。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

背景

因为近期工作需要,常常要将测试结果/数据统计、汇总和展示,因此会有写静态HTML的需求,本文记录下python写静态HTML的小技巧

灵感

灵感时来源于unittest测试框架最常用的报告插件:HTMLTestRunner,该插件本身基于python2且已经更新了,好在@虫师一直在维护和更新这个插件,使得它能继续被大家所使用,了解详情请移步:SeldomQA/HTMLTestRunner

回到HTMLTestRunner报告插件,阅读源码发现,作者只用了一个python文件便巧妙的将写HTML、页面绘制和数据嵌入搞定了。进一步分析可以看到,作者先是在Template基类中定义了测试报告的HTML结构模板和各个模块/表格模板,然后再以格式化输入的形式给每一个模板中填充目标数据,再将填充好的模板以格式化输入的形式填充到HTML结构模板中,最后再将所有内容写成一个HTML文件即可。

class Template_mixin(object):

"""

Define a HTML template for report customerization and generation.

Overall structure of an HTML report

HTML

+------------------------+

| |

|

|

| |

| STYLESHEET |

| +----------------+ |

| | | |

| +----------------+ |

| |

| |

| |

|

|

| |

| HEADING |

| +----------------+ |

| | | |

| +----------------+ |

| |

| REPORT |

| +----------------+ |

| | | |

| +----------------+ |

| |

| ENDING |

| +----------------+ |

| | | |

| +----------------+ |

| |

| |

| |

+------------------------+

"""

可以看到,这样的设计其实优点在于非常小巧和轻量,缺点在于可维护和可移植性差,数据量小还尚可,不太适合大量数据的统计和绘制。

技巧

这种设计的关键在于建模板,然后按需填充数据,最后再写HTML,通常我的做法是:

网上找到想要的页面或着表格,copy其HTML结构,将变动的部分(需要动态填充数据的部分)提取出来,并用格式化输入形式替代,如:%(style)s, %(rows)s

HTML_TMPL = r"""

Overview

%(style)s

总览

#设备环境耗时结果统计报告

%(rows)s

       

%(total)s

""" # style, rows, total

将变动的部分单拎出来,形成模板,依然用格式化输入形式替代

TBODY_TOTAL_TMPL = """

合计 通过率: {passing_rate}%    失败率: {failure_rate}%

   错误率: {error_rate}%    跳过率: {skip_rate}%

"""

按照模板格式,组装数据并填充

total += TBODY_TOTAL_TMPL.format(

passing_rate=np.mean(p_rates).round(2),

failure_rate=np.mean(f_rates).round(2),

error_rate=np.mean(e_rates).round(2),

skip_rate=np.mean(s_rates).round(2))

最后将所有数据填充到主模板,并写HTML

# write reporter

with open(filepath, 'w', encoding='utf-8') as wf:

wf.write(HTML_TMPL % dict(rows=rows, total=total, style=STYLE_TMPL))

扩展

目前python自动化测试常用的报告插件还有,allure

除过本文介绍写HTML的方法之外,还可以使用,jinjia2

<think>嗯,用户问的是如何将Python代码写入HTML。这个问题看起来是关于如何在网页中嵌入或展示Python代码,可能需要考虑几个方面。首先,我要确认用户的具体需求是什么。他们是想在HTML页面上运行Python代码,还是仅仅展示代码示例?或者可能想在后端用Python生成HTML内容? 如果是前者,即在浏览器中运行Python,这通常不太直接,因为浏览器主要执行JavaScript。不过,可以通过工具如PyScript来实现,这允许在HTML中嵌入Python代码。但需要确认用户是否了解这个框架,或者是否需要更基础的解决方案。 如果是展示代码,用户可能希望高亮显示Python语法,这时候需要使用代码高亮库,比如Prism.js或Highlight.js。这时候需要指导用户在HTML中使用<pre>和<code>标签,并引入相应的CSS和JS文件。 另外,用户可能想在后端用Python生成动态HTML内容,比如使用Flask或Django框架,将Python变量插入到模板中。这时候需要解释模板引擎的使用方法,比如Jinja2。 需要分步骤回答,先明确不同情况下的解决方案。可能用户不太清楚这些区别,所以需要逐一说明。同时,注意用户是否具备后端开发的知识,或者是否需要前端展示的简单方法。 还要检查是否需要提供具体的代码示例,比如如何在HTML中使用PyScript,或者如何用Flask渲染模板。确保示例代码正确,符合LaTeX格式的要求,但这里用户的问题是关于代码写入HTML,所以可能需要展示HTML结构中的Python代码嵌入方式。 另外,注意用户可能遇到的常见问题,比如转义字符的处理,或者如何确保代码在浏览器中正确显示而不是执行。例如,使用<pre>标签保留格式,同时替换特殊字符如<、>、&等为HTML实体。 最后,总结不同方法的适用场景,帮助用户根据需求选择合适的方式。例如,PyScript适合前端执行,模板引擎适合后端生成动态内容,代码高亮库适合静态展示代码示例。</think>将Python代码写入HTML主要有以下几种应用场景和实现方法,我将分步骤为您讲解: 1. **单纯展示代码(静态内容)** - 使用`<pre>`和`<code>`标签保留格式 ```html <pre><code class="language-python"> def hello(): print("Hello World!") </code></pre> ``` - 需要配合代码高亮库(如Prism.js)实现语法着色 ```html <link href="prism.css" rel="stylesheet" /> <script src="prism.js"></script> ``` 2. **动态生成HTML(服务端渲染)** - 使用Python Web框架(如Flask): ```python from flask import Flask, render_template app = Flask(__name__) @app.route('/') def index(): data = {"title": "动态页面", "content": "来自Python数据"} return render_template('index.html', **data) ``` - HTML模板(Jinja2语法): ```html <!DOCTYPE html> <html> <head> <title>{{ title }}</title> </head> <body> <p>{{ content }}</p> </body> </html> ``` 3. **浏览器端执行Python(客户端运行)** - 使用PyScript框架: ```html <!DOCTYPE html> <html> <head> <link rel="stylesheet" href="https://pyscript.net/latest/pyscript.css" /> <script defer src="https://pyscript.net/latest/pyscript.js"></script> </head> <body> <py-script> print("Hello from Python!") </py-script> </body> </html> ``` 4. **API交互(前后端分离)** - Python后端提供API: ```python # Flask示例 @app.route('/api/data') def get_data(): return {"values": [1, 2, 3]} ``` - HTML前端通过JavaScript调用: ```html <script> fetch('/api/data') .then(response => response.json()) .then(data => { document.getElementById('output').innerHTML = data.values; }); </script> ``` **注意事项:** 1. 转义处理:使用`html.escape()`防止XSS攻击 2. 性能优化:服务端渲染注意缓存机制 3. 安全性:客户端执行Python需谨慎处理敏感逻辑 4. 浏览器兼容性:PyScript等新技术需考虑兼容性 根据具体需求选择合适的方式: - 展示代码片段 → 静态展示方案 - 动态内容生成 → 服务端渲染 - 复杂交互应用 → 前后端分离架构 - 教学演示场景 → PyScript方案 需要更详细的实现示例或遇到具体问题,可以告诉我您的使用场景,我会提供针对性指导。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值