Python代码在Jinja模板中不起作用

时间:2015-08-07 07:30:01

标签: python python-2.7 python-3.x flask jinja2

我的程序有以下列表:

  • 模块 - 父列表
  • 子模块 - 父列表的子项
  • 小计 - 告诉我们在模块

  • 之后应该打印多少个子模块
  • 子内容 - 子模块的子项

  • contenttotal - 告知子模块
  • 后应打印多少子内容
module = [{'moduletitle': 'Parent Module 1', 'position': '1'}, {'moduletitle': 'Parent Module 2', 'position': '2'}, {'moduletitle': 'Parent Module 3', 'position': '3'}]

submodule = [{'moduletitle': 'sub module 11', 'position': '1'}, {'moduletitle': 'sub module 22', 'position': '2'}, {'moduletitle': 'sub module 1', 'position': '1'}, {'moduletitle': 'sub module 2', 'position': '3'}] 

subtotal = [2,2,0]  

subcontent = [{'content': 'Dj.docx', 'position': '10', 'contenttype': 'Pdf/Doc', 'coursemoduleid': 55341, 'contenttitle': 'test content'}] contenttotal=[0,0,1,0]
i1=0
i2=0
m=0
n=0
for i in range(0,len(module)):
    print module[i]['moduletitle']
    for j in range(0,subtotal[i1]):
        print "\t",submodule[m]['moduletitle']
        m=m+1
        for k in range(0, contenttotal[i2]):
            print "\t\t",subcontent[n]['content']
            n=n+1

        i2=i2+1
    i1=i1+1

它产生了预期的结果:

Parent Module 1
        sub module 11
        sub module 22
Parent Module 2
        sub module 1
                Dj.docx
        sub module 2
Parent Module 3

现在,当我在这样的Jinja模板中运行相同的代码时:

{% set i1=0 %}
{% set i2=0 %}
{% set m=0 %}
{% set n=0 %}
{% for i in range(0,moduledata | length ) %}

    {{ moduledata[i]['moduletitle'] }} <br>


    {% for j in range(0,subtotal[i1]) %}

        {{ subparent[m]['moduletitle'] }}<br>

        {% set m=m+1 %}

        {% for k in range(0, subtotalcontent[i2]) %}

                {{ subcontent[n]['content'] }}<br>

                {% set n=n+1 %}

        {% endfor %}

        {% set i2=i2+1 %}

    {% endfor %}
            {% set i1=i1+1 %}  
{%endfor%}

注意:我已将Jinja模板中的列表重命名为:

  • moduledata
  • subparent
  • 小计
  • 子内容
  • subtotalcontent

我在这里运行相同的代码是我收到的输出:

Parent Module 1 
sub module 11
sub module 22

Parent Module 2 
sub module 11
sub module 22
Parent Module 3

为了确保在将数据发送到模板时我没有犯错,我尝试在控制台上打印它们,这就是我得到的:

[{'moduletitle': 'Parent Module 1', 'position': '1'}, {'moduletitle': 'Parent Module 2', 'position': '2'}, {'moduletitle': 'Parent Module 3', 'position': '3'}]

[{'moduletitle': 'sub module 11', 'position': '1'}, {'moduletitle': 'sub module 22', 'position': '2'}, {'moduletitle': 'sub module 1', 'position': '1'}, {'moduletitle': 'sub module 2', 'position': '3'}] 

[2,2,0]     

[{'content': 'Dj.docx', 'position': '10', 'contenttype': 'Pdf/Doc', 'coursemoduleid': 55341, 'contenttitle': 'test content'}] 

[0,0,1,0]

因此两个程序都有相同的数据,但输出不同。

1 个答案:

答案 0 :(得分:1)

我同意Martijn所说的,如果你使用一个合适的嵌套数据结构,那么迭代就变得容易了,python与jinja语义不再重要。

以下是如何将所有列表转换为适当的嵌套结构的示例:

import pprint

modules = [
    {'moduletitle': 'Parent Module 1', 'position': '1'},
    {'moduletitle': 'Parent Module 2', 'position': '2'},
    {'moduletitle': 'Parent Module 3', 'position': '3'},
]

submodules = [
    {'moduletitle': 'sub module 11', 'position': '1'},
    {'moduletitle': 'sub module 22', 'position': '2'},
    {'moduletitle': 'sub module 1', 'position': '1'},
    {'moduletitle': 'sub module 2', 'position': '3'},
]

subtotal = [2, 2, 0]

subcontent = [
    {'content': 'Dj.docx', 'position': '10', 'contenttype': 'Pdf/Doc', 'coursemoduleid': 55341, 'contenttitle': 'test content'},
]

contenttotal = [0, 0, 1, 0]

###

#first, nest the "subcontent" items in the "submodule" items
subcontent_iter = iter(subcontent)
for sub, num_content_items in zip(submodules, contenttotal):
    tmp = []
    for i in range(num_content_items):
        tmp.append(next(subcontent_iter))
    sub['content'] = tmp

#then, nest the "submodule" items under the "module" items
submodule_iter = iter(submodules)
for (module, num_submodules) in zip(modules, subtotal):
    tmp = []
    for i in range(num_submodules):
        tmp.append(next(submodule_iter))
    module['submodules'] = tmp

pprint.pprint(modules)

输出:

[{'moduletitle': 'Parent Module 1',
  'position': '1',
  'submodules': [{'content': [],
                  'moduletitle': 'sub module 11',
                  'position': '1'},
                 {'content': [],
                  'moduletitle': 'sub module 22',
                  'position': '2'}]},
 {'moduletitle': 'Parent Module 2',
  'position': '2',
  'submodules': [{'content': [{'content': 'Dj.docx',
                               'contenttitle': 'test content',
                               'contenttype': 'Pdf/Doc',
                               'coursemoduleid': 55341,
                               'position': '10'}],
                  'moduletitle': 'sub module 1',
                  'position': '1'},
                 {'content': [],
                  'moduletitle': 'sub module 2',
                  'position': '3'}]},
 {'moduletitle': 'Parent Module 3', 'position': '3', 'submodules': []}]

了解此数据结构现在看起来与您想要的输出类似?它遵循相同的嵌套模块模式 - &gt;子模块 - &gt;内容。

迭代现在变成了小菜一碟,只需嵌套三个循环并每次迭代当前级别的孩子,不再需要跟踪这么多索引:

for module in modules:
    print module['moduletitle']
    for submodule in module['submodules']:
        print "  ", submodule['moduletitle']
        for content in submodule['content']:
            print "    ", content['content']

输出:

Parent Module 1
   sub module 11
   sub module 22
Parent Module 2
   sub module 1
     Dj.docx
   sub module 2
Parent Module 3

这个更简单的迭代应该在jinja中正常工作。

IMO如果你在jinja代码中加入如此多的逻辑,你更有可能遇到问题。我更喜欢纯python代码用于这种数据操作,并且只使用jinja来进行数据的轻量级表示。与jinja相比,纯Python代码更容易编写,调试和测试。