Я новичок в Джанго, поэтому вопрос может быть глупым, но, пожалуйста, не стесняйтесь учить меня правильному пути, если вы это знаете.
Я попытался погуглить вопрос, но я все еще в растерянности.
Вот моя проблема:
В моей модели есть класс с двумя внешними ключами:
class X(models.Model):
name = models.CharField(max_length=30)
def __unicode__(self):
return name
class Y(models.Model):
name = models.CharField(max_length=30)
def __unicode__(self):
return name
class Z(models.Model):
name = models.CharField(max_length=30)
x = models.ForeignKey(X)
y = models.ForeignKey(Y)
def __unicode__(self):
return name
На мой взгляд, я получаю частичный список объектов X и частичный список объектов Y, например:
def MyView(x_pattern, y_pattern):
x_list = X.objects.filter(name__contains=x_pattern)
y_list = Y.objects.filter(name__contains=y_pattern)
z_list = Z.objects.all()
return render_to_response({'x_list': x_list, 'y_list': y_list, 'z_list': z_list})
В моем шаблоне я хотел бы иметь возможность отображать таблицу следующим образом:
<table>
<tr>
<td>Y</td>
{% for x in x_list %}
<td>{{ x }}</td>
{% endfor %}
</tr>
{% for y in y_list %}
<tr>
<td>{{ y }}</td>
{% for x in x_list %}
<td>
<!-- here I need help:
I need to display z[x, y] if it exists, or "N/A" otherwise.
-->
</td>
{% endfor %}
</tr>
{% endfor %}
Как мне сделать это правильно в Django?
Большое спасибо,