Ich habe einen Veranstaltungsort, an dem viele Veranstaltungen stattfinden. Meine Modelle sehen so aus:
class Event(models.Model):
title = models.CharField(max_length=200)
date_published = models.DateTimeField('published date',default=datetime.now, blank=True)
date_start = models.DateTimeField('start date')
date_end = models.DateTimeField('end date')
def __unicode__(self):
return self.title
description = models.TextField()
price = models.IntegerField(null=True, blank=True)
venue = models.ForeignKey(Venue)
class Venue(models.Model):
title = models.CharField(max_length=200)
date_published = models.DateTimeField('published date',default=datetime.now, blank=True)
venue_latitude = models.CharField(max_length=200)
venue_longitude = models.CharField(max_length=200)
venue_address = models.CharField(max_length=200)
venue_city = models.CharField(max_length=200)
venue_state = models.CharField(max_length=200)
venue_country = models.CharField(max_length=200)
description = models.TextField()
def __unicode__(self):
return u'%s' % (self.title)
Ich möchte alle Ereignisse anzeigen, die an einem bestimmten Ort stattfinden. Wie kann ich das machen? Meine aktuelle Ansicht sieht aus wie:
def detail(request, venue_id):
venue = get_object_or_404(Venue, pk=venue_id)
return render(request, 'venue-detail.html', {'venue': venue})
Antworten:
Sie können verwenden
events = venue.event_set
, um den anderen Weg zu gehen.Beachten Sie, dass es sich um ein Managerobjekt handelt
venue.event_set
, wieEvent.objects
Sie es aufrufen.all
können.filter
,.exclude
und ähnliches, um ein Abfrageset abzurufen.Siehe die Django-Dokumentation
quelle
AttributeError: 'Foo' object has no attribute 'bar_set'
, möchten Sie möglicherweise überprüfen, ob errelated_name
auf demForeignKey
/OneToOneField
/ManyToManyField
des untergeordneten Modells (Bar
) festgelegt ist, das auf das übergeordnete Modell (Foo
) verweist .Für diejenigen, die "'RelatedManager' Objekt ist nicht iterierbar"
Fügen Sie alle hinzu, um die Elemente vom Manager abzurufen.
{% for area in world_areas.all %}
https://stackoverflow.com/a/16909142/2491526 (kann dies nicht im Kommentar zur ersten Antwort hinzufügen)
quelle
Geh den umgekehrten Weg. Verwenden
Event
Modell.def detail(request, venue_id): venue = Event.objects.filter(venue__id=venue_id) return render(request, 'venue-detail.html', {'venue': venue})
PS: Ich habe noch nie benutzt
get_object_or_404()
. Ändern Sie den Code entsprechend.quelle
{% for i in venue %} {{ i.venue.title }}
for
venue = Event.objects.filter(venue__id=venue_id)
Ich denke, dieser Ausdruck gibt QuerySet of Event-Objekt anstelle von Venue-Objekt zurück.