У меня есть объект базы данных с именем manor_stats
, содержащий около 30 полей. Для большинства строк большинство этих полей будут нулевыми.
В моем шаблоне я хотел бы пройтись по всем полям в строке и распечатать информацию только для тех полей, которые не равны нулю.
Например, есть поле под названием «имя»: я хотел бы напечатать <li>Name: {{ manor_stats.name }}</li>
в шаблоне ТОЛЬКО для тех объектов, где поле не равно нулю. В идеале я хотел бы получить «Имя:» откуда-то автоматически, а не указывать его.
Я знаю, что могу использовать {% if manor_stats.name %}
, чтобы проверить, является ли каждое поле пустым, но я не хочу делать это 30 раз для всех полей.
Вот что у меня есть в views.py:
manor_stats = Manors.objects.get(idx=id)
return render_to_response('place.html', { 'place' : place, 'manor_stats' : manor_stats }, context_instance = RequestContext(request))
И затем в place.html я хотел бы иметь что-то, что работает примерно так (псевдокод, где ??? указывает на биты, которые я не знаю, как сделать):
{% if manor_stats %}
<ul>
{% for manor_stats.property??? in manor_stats %}
{% if manor_stats.property %}
<li>{{ manor_stats.property.field_name??? }} {{ manor_stats.property.value??? }}</li>
{% endif %}
{% endfor %
{% endif %}
Надеюсь, это имеет смысл...