我想为我的主页创建内容片段。示例帖子看起来像
<p>Your favorite Harry Potter characters enter the Game of Thrones
universe, and you'll never guess what happens!</p>
<readmore/>
<p>...they all die</p>
在主页上,我只希望显示<readmore/>
之前的内容。我想我可以在Jinja过滤器中使用Beautiful Soup来删除readmore以及之后的所有内容。如果没有<readmore/>
,它应该在第一个换行符或段落结尾处剪辑。
我该怎么做?
答案 0 :(得分:4)
没有必要使用美丽的汤。只需检查文本中是否存在<readmore/>
或其他子字符串,并在其上拆分,或者在换行符中是否存在拆分。
from markupsafe import Markup
@app.template_filter()
def snippet(value):
for sep in ('<readmore/>', '<br/>', '<br>', '</p>'):
if sep in value:
break
else:
sep = '\n'
return Markup(value.split(sep, 1)[0])