我有一个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
我将不胜感激。
答案 0 :(得分:1)
好的,我意识到这是for语句中的语法错误,应该是:
{% for q in query %}
{% endfor %}}