如何将Mongo Cursor对象传递给Jinja模板?

时间:2016-06-17 00:51:02

标签: python mongodb python-2.7 jinja2 pymongo

我有一个Mongo数据库,我想创建一个执行查询的脚本并将结果传递给html文件。

此呈现的html文件将用作我将发送给同事的电子邮件的html正文。

然而,模板没有渲染,这就是我所拥有的

我的HTML看起来像这样:

     <table>
        { %for q in query %}
            <tr>
                <td>{{ q['containers'] }} </td>
                <td>{{ q['cases'] }} </td>
                <td>{{ q['gross_weight'] }} </td>
                <td>{{ q['volume'] }} </td>
            </tr>
        { %endfor% }
    </table>

虽然我的脚本看起来像这样:

from pymongo import MongoClient, ASCENDING
from jinja2 import Template

def main():

    client = MongoClient()
    collection = client.supplyChain['commonRegimes']

    parameters = {
        'delivery_to_warehouse':None,
        'regime':{'$in':['10', '91']}
    }

    query_result = collection.find(parameters).sort('eta_warehouse', ASCENDING)

    templatefile = open('D:/myScripts/ccreport/reports/templates/nextArrivals.html').read()

    template = Template(templatefile)

    message  = template.render(query = query_result)


if __name__ == '__main__':
    main()

我收到错误:

jinja2.exceptions.UndefinedError: 'q' is undefined

我将不胜感激。

1 个答案:

答案 0 :(得分:1)

好的,我意识到这是for语句中的语法错误,应该是:

{% for q in query %}

{% endfor %}}