Как получить доступ к полевым данным «многие ко многим» из другой модели? - PullRequest
0 голосов
/ 29 января 2020

У меня есть следующие модели:

class Work_Music(MPTTModel, Work):
    name = models.CharField(max_length=10, null=True, blank=True)   
    key = models.CharField(max_length=10, null=True, blank=True)
    tonality = models.CharField(max_length=20, null=True, blank=True)

class WorkCast(models.Model):
    work = models.ForeignKey(Work_Music, verbose_name=_('work'), related_name='workcast', null=True, blank=True, on_delete=models.PROTECT)
    cast = models.ManyToManyField(Cast, verbose_name=_('cast'), related_name='workcast', blank=True)
    order = models.DecimalField(max_digits=100, decimal_places=2, null=True, blank=True)

class Cast(models.Model):
    name = models.CharField(max_length=100, null=True, blank=True)

В view.py я отправляю следующее в контексте шаблона:

work = Work_Music.objects.get(work=self.kwargs['pk'])

Как получить доступ к WorkCast через Work_Musi c object?

Как отобразить в шаблоне

 Cast #1, Cast #2, Cast #3, Cast #4

Как мне получить все члены актерского состава? Это так?

work.workcast.cast.all()

не дает никакого вывода.

Как отобразить его в виде списка с запятыми между?

1 Ответ

0 голосов
/ 29 января 2020

Я думаю, что вы имеете в виду обратную ссылку модели _set в django. Вы можете найти больше информации здесь . В вашем случае вы бы сделали что-то вроде

work_music = WorkMusic.object.get(pk=1)
work_music.workcast_set.all() # would get you all workcast related to that work music object

Надеюсь, это поможет!

...