如何使用 django-tables2 连接两个表

Max*_*ram 2 join django-tables2

任何人都可以提供一个清晰的示例,说明如何使用django-tables2从两个(或更多)相关模型中选择和呈现数据来显示表格?

我发现了很多关于这个的帖子,其中大多数都很老,而且没有一个真正有效的例子。

这些是我的模型:

class Person(models.Model):
    name = models.CharField(verbose_name="Name",max_length=50)
    fname = models.CharField(verbose_name="F.Name",max_length=50)

class Speech(models.Model):
    person = models.ForeignKey(Person, on_delete=models.CASCADE)
    said = models.CharField(verbose_name="Said",max_length=50)
Run Code Online (Sandbox Code Playgroud)

我只想显示一个包含“姓名、F.姓名、赛义德”列的表格。哪种方法最好?并且有多个表?

提前致谢。

Max*_*ram 5

嗯,没有人回答我的问题。在挖掘和尝试之后,我找到了一种在一个表中显示来自相关模型的字段的方法。问题是tables.py中的表定义应该是这样的:

class SpeechTable(tables.Table):
    name = tables.Column(accessor='person.name')
    fname = tables.Column(accessor='person.fname')
    said = tables.Column()
    class Meta:        
        attrs = {"class": "paleblue"}
Run Code Online (Sandbox Code Playgroud)

不确定这是否是最好的方法,但它很简单并且工作正常。