我在这方面遇到很大困难。
我正在尝试渲染我的模板,如下所示:
公司名称A:
- >邮政编码1
- >邮政编码2
我现在有这个结果:
公司名称A:
- >邮政编码1
公司名称A:
- >邮政编码2
我知道它来自for循环,但我不知道如何访问M2M字段以显示它。 (我有一个额外的m2m字段,所以它将是另一个for循环)
这是我的代码:
models.py
class Company(models.Model):
utilisateur = models.ForeignKey(User)
nom_cpny = models.CharField(max_length=200)
code_postal_cpny = models.ManyToManyField('Place', blank=True)
gestion_cpny = models.ManyToManyField('Companytype', blank=True)
def __unicode__(self):
return self.nom_cpny
class Place(models.Model):
postalcode = models.CharField(max_length=200)
ville = models.CharField(max_length=200)
region = models.CharField(max_length=200)
departement = models.CharField(max_length=200)
longitude = models.DecimalField(max_digits=9, decimal_places=6)
latitude = models.DecimalField(max_digits=9, decimal_places=6)
pays = models.CharField(max_length=100)
def __unicode__(self):
return unicode(self.postalcode)
class Companytype(models.Model):
cpny_type = models.CharField(max_length=100, blank=False)
employee_base = models.IntegerField(blank=False)
def __unicode__(self):
return self.cpny_type
views.py
@login_required
def listing_cpny(request):
cpny_in = Company.objects.all().filter(utilisateur=request.user)
utilisateur = request.user
args = {}
args.update(csrf(request))
args['cpny_in'] = cpny_in
args['utilisateur'] = utilisateur
return render_to_response('b_dashboard_annonces.html', args) views.py
b_dashboard_annonces.html
{% for annonce in cpny_in %}
{% for cp in annonce.code_postal_cpny.all %}
{% if annonce.utilisateur.id == utilisateur.id %}
<td>{{annonce.nom_cpny}}</td>
<td>{{cp }}</td>
</tr>
{% endif %}
{% endfor %}
{% endfor %}
非常感谢你的帮助!
答案 0 :(得分:2)
这应该对你有用
{% for annonce in cpny_in %}
<tr>
<td>{{annonce.nom_cpny}}</td>
{% for cp in annonce.code_postal_cpny.all %}
{% if annonce.utilisateur.id == utilisateur.id %}
<td>{{cp }}</td>
{% endif %}
{% endfor %}
</tr>
{% endfor %}