用 jinja2 模板,{{ content.html | safe | truncate(500) }} 截断 html 内容之后,有时候刚巧会截到 500 个字符的地方是 html 标签的闭合位置,造成一半标签留在页面上,另外一半被截掉了,例如这样:
text text text text text <code>
print('hello world ...
剩下的 ')</code>
就被截掉了。最糟糕的是,如果这个 truncate()是在一个 loop 里,浏览器 Chrome/Firefox 都会自作聪明的在后面自动补全来关闭标签。结果整个页面就全乱掉了
1
ipwx 2018-02-22 00:12:56 +08:00 1
Better Google it yourself next time.
https://stackoverflow.com/questions/4970426/html-truncating-in-python |
2
cxh116 2018-02-22 08:52:44 +08:00 via Android 1
最简单的做法就是删除所有标签再截取。
想保留的话,有种做法就是用 html 解析库,有的解析库支持补全闭合标签。 |