如何在一个元素上使用多个自定义的Jinja过滤器 - python

我已经为Jinja模板创建了两个自定义过滤器。当我尝试将两个过滤器应用于一个元素时,只有一个过滤器将起作用。如何使两个过滤器都起作用?

{{ post.content|makeimg|taguser|truncate(200)|urlize(40, true) }}

除第二个过滤器外,所有其他过滤器均有效。前两个过滤器是我制作的。

这是过滤器的代码:

@app.template_filter('taguser')
    def taguser(text):
    return Markup(re.sub(r'@([a-zA-Z0-9_]+)', r'<a href="/\1">@\1</a>', text))

@app.template_filter('makeimg')
    def makeimg(text):
    return Markup(re.sub(r'img([a-zA-Z0-9_./:-]+)', r'<img width="100px" src="\1">', text))

示例帖子:

Hey, @john. imghttp://image.com/image.jpeg 

参考方案

问题不在过滤器上。两个过滤器均按预期工作。

您的错误是您两次调用Markup方法。

以下修复程序对我有用(仅在最后一个过滤器中调用Markup):

HTML模板(不变):

{{ post.content|makeimg|taguser|truncate(200)|urlize(40, true) }}

码:

@app.template_filter('taguser')
def taguser(text):
    return Markup(re.sub(r'@([a-zA-Z0-9_]+)', r'<a href="/\1">@\1</a>', text))

@app.template_filter('makeimg')
def makeimg(text):
    return re.sub(r'img([a-zA-Z0-9_./:-]+)', r'<img width="100px" src="\1">', text)

R'relaimpo'软件包的Python端口 - python

我需要计算Lindeman-Merenda-Gold(LMG)分数,以进行回归分析。我发现R语言的relaimpo包下有该文件。不幸的是,我对R没有任何经验。我检查了互联网,但找不到。这个程序包有python端口吗?如果不存在,是否可以通过python使用该包? python参考方案 最近,我遇到了pingouin库。

Python:传递记录器是个好主意吗? - python

我的Web服务器的API日志如下:started started succeeded failed 那是同时收到的两个请求。很难说哪一个成功或失败。为了彼此分离请求,我为每个请求创建了一个随机数,并将其用作记录器的名称logger = logging.getLogger(random_number) 日志变成[111] started [222] start…

用大写字母拆分字符串,但忽略AAA Python Regex - python

我的正则表达式:vendor = "MyNameIsJoe. I'mWorkerInAAAinc." ven = re.split(r'(?<=[a-z])[A-Z]|[A-Z](?=[a-z])', vendor) 以大写字母分割字符串,例如:'我的名字是乔。 I'mWorkerInAAAinc”变成…

Python-Excel导出 - python

我有以下代码:import pandas as pd import requests from bs4 import BeautifulSoup res = requests.get("https://www.bankier.pl/gielda/notowania/akcje") soup = BeautifulSoup(res.cont…

Python:如何根据另一列元素明智地查找一列中的空单元格计数? - python

df = pd.DataFrame({'user': ['Bob', 'Jane', 'Alice','Jane', 'Alice','Bob', 'Alice'], 'income…