จะวนซ้ำผ่านพจนานุกรมในพจนานุกรมในเทมเพลต django ได้อย่างไร


128

พจนานุกรมของฉันมีลักษณะดังนี้ (พจนานุกรมภายในพจนานุกรม):

{'0': {
    'chosen_unit': <Unit: Kg>,
    'cost': Decimal('10.0000'),
    'unit__name_abbrev': u'G',
    'supplier__supplier': u"Steve's Meat Locker",
    'price': Decimal('5.00'),
    'supplier__address': u'No\r\naddress here',
    'chosen_unit_amount': u'2',
    'city__name': u'Joburg, Central',
    'supplier__phone_number': u'02299944444',
    'supplier__website': None,
    'supplier__price_list': u'',
    'supplier__email': u'ss.sss@ssssss.com',
    'unit__name': u'Gram',
    'name': u'Rump Bone',
}}

ตอนนี้ฉันแค่พยายามแสดงข้อมูลในเทมเพลตของฉัน แต่ฉันกำลังดิ้นรน รหัสของฉันสำหรับเทมเพลตดูเหมือนว่า:

{% if landing_dict.ingredients %}
  <hr>
  {% for ingredient in landing_dict.ingredients %}
    {{ ingredient }}
  {% endfor %}
  <a href="/">Print {{ landing_dict.recipe_name }}</a>
{% else %}
  Please search for an ingredient below
{% endif %}

มันแสดงให้ฉันเห็น '0' บนเทมเพลตของฉันหรือไม่

ฉันยังลอง:

{% for ingredient in landing_dict.ingredients %}
  {{ ingredient.cost }}
{% endfor %}

สิ่งนี้ไม่ได้แสดงผลด้วยซ้ำ

ฉันคิดว่าบางทีฉันอาจต้องทำซ้ำให้ลึกขึ้นอีกหนึ่งระดับจึงลองทำสิ่งนี้:

{% if landing_dict.ingredients %}
  <hr>
  {% for ingredient in landing_dict.ingredients %}
    {% for field in ingredient %}
      {{ field }}
    {% endfor %}
  {% endfor %}
  <a href="/">Print {{ landing_dict.recipe_name }}</a>
{% else %}
  Please search for an ingredient below
{% endif %}

แต่นี่ไม่แสดงอะไรเลย

ผมทำอะไรผิดหรือเปล่า?

คำตอบ:


259

สมมติว่าข้อมูลของคุณคือ -

data = {'a': [ [1, 2] ], 'b': [ [3, 4] ],'c':[ [5,6]] }

คุณสามารถใช้data.items()วิธีการรับองค์ประกอบพจนานุกรม หมายเหตุในแม่แบบ Django ()เราไม่ได้ใส่ นอกจากนี้ยังมีผู้ใช้บางคนที่กล่าวถึงไม่ทำงานถ้าเป็นกรณีแล้วลองvalues[0]values.items

<table>
    <tr>
        <td>a</td>
        <td>b</td>
        <td>c</td>
    </tr>

    {% for key, values in data.items %}
    <tr>
        <td>{{key}}</td>
        {% for v in values[0] %}
        <td>{{v}}</td>
        {% endfor %}
    </tr>
    {% endfor %}
</table>

ค่อนข้างแน่ใจว่าคุณสามารถขยายตรรกะนี้ไปยังคำสั่งเฉพาะของคุณได้


ในการวนซ้ำบนปุ่ม dict ตามลำดับที่เรียงลำดับ - อันดับแรกเราเรียงลำดับใน python จากนั้นทำซ้ำและแสดงผลในเทมเพลต django

return render_to_response('some_page.html', {'data': sorted(data.items())})

ในไฟล์เทมเพลต:

{% for key, value in data %}
    <tr>
        <td> Key: {{ key }} </td> 
        <td> Value: {{ value }} </td>
    </tr>
{% endfor %}

2
ขอบคุณสำหรับคำตอบ. ฉันมีสูตรอาหารขึ้นหนึ่งระดับและไม่ได้แสดงระดับนั้นของพจนานุกรม ขอบคุณสำหรับคำตอบ! ฉันไม่สามารถใช้values[0]แทนได้values.items
darren

เย็น! ดีใจที่ได้แบ่งปันสิ่งที่ฉันรู้ รหัสถูกพิมพ์ด้วยมือเปล่าดังนั้นข้อผิดพลาดบางประการจึงหลีกเลี่ยงไม่ได้
Srikar Appalaraju

1
.itemsขอขอบคุณสำหรับการกล่าวขวัญ เอกสารประกอบhttps://docs.djangoproject.com/en/1.4/topics/templates/เป็นตัวอย่างที่ใช้ไม่ได้ แต่ไม่มีตัวอย่างที่ใช้งานได้ {% for k,v in dict %}ให้ผลลัพธ์ที่แปลกประหลาด - k เป็นอักขระตัวแรกของทุกคีย์และ v ว่างเปล่าในขณะที่{% for k in dict %}ส่งคืนคีย์เต็ม แต่ไม่มีวิธีการดึงค่า (เนื่องจากdict.kถือว่า k เป็นอักขระตามตัวอักษร)
Dave

2
โหวต :-) สำหรับผู้อ่านในอนาคตแท็กและตัวกรองจะอ้างอิงhttps://docs.djangoproject.com/en/1.8/ref/templates/builtins/#forเอกสารนี้พร้อมกับตัวแปร forloop ที่มีประโยชน์เมื่อจัดรูปแบบรายการ
Dave

1
values.items+1
Kevin_TA

3

คำตอบนี้ไม่ได้ผลสำหรับฉัน แต่ฉันพบคำตอบด้วยตัวเอง อย่างไรก็ตามไม่มีใครโพสต์คำถามของฉัน ฉันขี้เกียจที่จะถามแล้วตอบดังนั้นจะใส่ไว้ตรงนี้

นี่คือแบบสอบถามต่อไปนี้:

data = Leaderboard.objects.filter(id=custom_user.id).values(
    'value1',
    'value2',
    'value3')

ในเทมเพลต:

{% for dictionary in data %}
  {% for key, value in dictionary.items %}
    <p>{{ key }} : {{ value }}</p>
  {% endfor %}
{% endfor %}

0

หากคุณส่งตัวแปรdata(ประเภทพจนานุกรม) เป็นบริบทไปยังเทมเพลตรหัสของคุณควรเป็น:

{% for key, value in data.items %}
    <p>{{ key }} : {{ value }}</p> 
{% endfor %}
โดยการใช้ไซต์ของเรา หมายความว่าคุณได้อ่านและทำความเข้าใจนโยบายคุกกี้และนโยบายความเป็นส่วนตัวของเราแล้ว
Licensed under cc by-sa 3.0 with attribution required.