来自实例的模型“through”表上的Django访问字段

2024-06-07 00:15:15 发布

您现在位置:Python中文网/ 问答频道 /正文

我和一个直通表有着多对多的关系,就像这样:

class Chapter(models.Model):
    name = models.CharField(max_length=255,)
    slides = models.ManyToManyField('Slide', blank=True, related_name='chapters', through='SlideOrder')
    # ...

class Slide(models.Model):
    title = models.CharField(max_length=255,)
    # ...

class SlideOrder(models.Model):
    chapter = models.ForeignKey(Chapter)
    slide = models.ForeignKey(Slide)
    number = models.PositiveIntegerField()

我可以按如下顺序获取一章的幻灯片:

chapter = Chapter.objects.get(pk=1)
chapter_slides = chapter.slides.order_by('slideorder')

但是,在处理单个幻灯片实例时,我无法访问幻灯片顺序:

slide = Slide.objects.get(pk=1)

如果在幻灯片实例上执行以下操作,则可以看到所有可能的字段:

print slide._meta.get_all_field_names()
['title', u'chapters', 'slideorder', u'id']

但是,尝试访问slideorder字段会提供以下信息:

slide.slideorder
Traceback (most recent call last):
  File "<console>", line 1, in <module>
AttributeError: 'Slide' object has no attribute 'slideorder'

我可以访问列出的所有属性,除了slideorder。如何访问幻灯片的顺序?


Tags: namegetmodel顺序modelsmaxclasschapter