0

在我看来,我从查询集中创建了以下列表字典

#view.py
queryset = MyModel.objects.filter(owner=user, dashboard=tab).order_by('position')
my_dict = collections.defaultdict(lambda: collections.defaultdict(list))    
for obj in queryset:
    my_dict[int(obj.position.split('-')[0])][int(obj.position.split('-')[2])].append(obj)
return Response({'queryset': dict(my_dict)}, template_name='dashboard/_maps_tab.html')

Position 字段是一个 charFiled,格式如下: XXXX used the create the my_dict

my_dict 是

--[1] #group
----[1] #col 1
------ object1.1.1 #group.col.pk
------ object1.1.2
------ object1.1.3
----[2] #col 2
------ object1.2.4
----[3] #col3
------ object1.3.5
------ object1.3.6

--[2] #group
----[1] #col 1
------object2.1.7 #group.col.pk

--[3] #group
----[1] #col1
------ object3.1.8 #group.col.pk
----[2] #col2
------object3.2.9
------object3.2.10

在我的模板中我想做

{% for groups in queryset.iteritems %}

    groups = {{ groups }} <br>

    {% for cols in groups %}

      cols = {{ cols }} <br>

      {% for objs in cols %}

        {{ objs }} in <br><br>

        {% for obj in objs %}        
          {{ obj.title }}, 
          {{ obj.desc}}, 
          {{ obj.fieldN }},         

        {% endfor %}

      {% endfor %}


    {% endfor %}

{% endfor %}

结果是

groups = (1, defaultdict(<type 'list'>, {1: [<Obj: Obj 1 by daviddd>, <Obj: Obj 2 by daviddd>, <Obj: Obj3 by daviddd>], 2: [<Obj: Obj 4 by daviddd>], 3: [<Obj: Obj 5 by daviddd>, <Obj: Obj 6 by daviddd>, <Obj: Obj 7 by daviddd>]}))
cols = 1
cols = defaultdict(<type 'list'>, {1: [<Obj: Obj 1 by daviddd>, <Obj: Obj 2 by daviddd>, <Obj: Obj3 by daviddd>], 2: [<Obj: Obj 4 by daviddd>], 3: [<Obj: Obj 5 by daviddd>, <Obj: Obj 6 by daviddd>, <Obj: Obj 7 by daviddd>]})

groups = (2, defaultdict(<type 'list'>, {1: [<Obj: Obj 7.7 by daviddd>]}))
cols = 2
cols = defaultdict(<type 'list'>, {1: [<Obj: Obj 7.7 by daviddd>]})

groups = (3, defaultdict(<type 'list'>, {1: [<Obj: Obj 7.8 by daviddd>]}))
cols = 3
cols = defaultdict(<type 'list'>, {1: [<Obj: Obj 7.8 by daviddd>]}) 

我试图做,{% for cols in groups.1 %}但它不工作(空)。如果我 {% for cols in groups.iteritems %} 我有:“Int is not iterable”。

查看https://code.djangoproject.com/ticket/16335我的情况是

my_dict = collections.defaultdict(lambda: collections.defaultdict(list))    
dictionary['foo']['foo1'].append('bar')

我该如何解决?

提前致谢!

D

4

1 回答 1

0

我的 view.py 解决方案是:

    my_dict = collections.defaultdict(lambda: collections.defaultdict(list))

    for obj in queryset:
        my_dict[int(obj.position.split('-')[0])][int(obj.position.split('-')[2])].append(obj)

    for obj in my_dict:            
        my_dict[obj].default_factory = None

    return Response({'queryset': dict(my_dict)}, template_name='_internal_template.html')

链接到https://code.djangoproject.com/ticket/16335Django 模板不能循环 defaultdict

我的模板

{% for groups in queryset.itervalues  %}

    groups = {{ groups }}    
    <br><br>

    {% for cols in groups.itervalues  %}

      cols = {{ cols }}    
      <br><br>

      {% for obj in cols  %}

        obj = {{ obj}} in <br><br>
        obj info = {{ obj.title }}, {{ obj.abstract }}<br>

      {% endfor %}      

    {% endfor %}

{% endfor %}
于 2013-08-26T09:42:20.160 回答