从Jinja temp调用Python函数

2024-05-23 23:43:55 发布

您现在位置:Python中文网/ 问答频道 /正文

有没有办法在Jinja模板中调用Python函数?函数将只接受字符串years,并将其转换为列表。

years = years.replace('[', '')
years = years.replace(']', '')
years = years.split(',')

我如何在下面的模板中的years上调用它?

{% extends "base.html" %}
{% import "_macros.html" as macros %}

{% block title %}Year Results{% endblock %}

{% block page_content %}
<div class="page-header">
    <h1>Year Search Results</h1>
</div>
<ul class=entries>
    {% for entry in entries %}
    <li><h3><a href="{{ url_for('main.grantinfo', applid=entry.appl_id) }}">{{ entry.appl_id }} : {{ entry.project_title }}</a></h3>
    <br>
    {% else %}
    <li><em>No entry here</em>
    {% endfor %}
</ul>

{% if pagination %}
<div class="pagination">
    {{ macros.pagination_widget(pagination, '.yearresults', years=years) }}
</div>
{% endif %}
{% endblock %}

Tags: 函数div模板titlehtmlpaginationblockendblock
3条回答

从模板中调用函数的一种方法是使用@app.context_processordecorator。

在python文件中,比如main.py

@app.context_processor
def my_utility_processor():

    def date_now(format="%d.m.%Y %H:%M:%S"):
        """ returns the formated datetime """
        return datetime.datetime.now().strftime(format)

    def name():
        """ returns bulshit """
        return "ABC Pvt. Ltd."

    return dict(date_now=date_now, company=name)

在像footer.html这样的html文件中

<p> Copyright {{ company() }} 2005 - {{ date_now("%Y") }} </p>

输出

Copyright ABC Pvt. Ltd. 2005 - 2015

years似乎是一个JSON列表,因此使用json.loads来解析它,而不是手动剥离和拆分字符串。years似乎是从视图发送到模板的变量,所以只需在视图中进行处理。

years = json.loads(years)
# years string "[1999, 2000, 2001]"
# becomes list [1999, 2000, 2001]
# without parsing the string manually
return render_template('years.html', years=years)

如果您真的需要在模板中使用它(您可能不需要),可以将json.loads添加到Jinja globals中。

app.add_template_global(json.loads, name='json_loads')

然后像普通函数一样在模板中使用它。

{{ macros.pagination_widget(pagination, '.yearresults', years=json_loads(years)) }}

可能如下:

在main.py文件中的第一个

def myYearLister(year):
    return year.INTOLISTORWHATEVER

然后在main.py中的某个地方包含以下内容(最好在函数之后执行),以便使函数可以全局访问

app.jinja_env.globals.update(myYearLister=myYearLister) 

最后,您可以调用或使用模板中的函数

<div> {{ myYearLister(anything) }} </div>

相关问题 更多 >