【python】使用字符串格式化渲染html

背景

被分配到一个小任务,即编写一个发送日报邮件的接口,且要求日报以 HTML 形式展示。

在查询和分析方面无需赘言,在渲染页面时却遭遇了一些小难题。

鉴于此任务仅仅是简单的发送邮件操作,专门去配置模板引擎或者采用前后端分离的方式显然不太必要。于是,我决定通过字符串格式化来实现。先编写一个 HTML 模板,在需要填充数据的位置用占位符占位,然后利用字符串格式化来渲染 HTML 。

然而,由于 HTML 模板中存在 CSS 样式,其“{}”语法与 Python 格式化字符串的语法产生了冲突。

解决方案

用“{ {}}”转义

将 CSS 中的“{}”全部替换为“{ {}}”,这种方法是可行的。在 Python 进行字符串格式化时,“{ {}}”中的“{}”及其他内容会被当作普通字符串处理,不会被格式化。

但当我开启 PyCharm 的代码格式化功能时,原本的“{ {}}”会被转换为“{\n{ }\n}”,因此使用起来较为麻烦,甚至不太能用。

将 HTML 模板拆分成“header” - “body” - “footer” 三部分

如此一来,只需对“body”部分进行格式化,其余部分保持不变。然后通过字符串拼接的方式组合成完整的 HTML 页面。

采用这种方式,就无需担忧 CSS 语法与字符串格式化语法的冲突。并且,如果存在 JavaScript 脚本,也可以写在“footer”部分。这样,可能出现“{}”符号的地方就都被成功分离了。

接着,针对“body”部分使用关键字参数进行字符串格式化,如此一来,看起来也更为直观。

比如像这样:

<div class="row">                                 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

星眺北海

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值