many to many in django-tables2

Обновить

November 2018

Просмотры

1.1k раз

1

У меня есть модели Джанго с многим ко многим через ForeignKey:

    class A(m.Model):
        id = m.AutoField(primary_key=True)
        name = m.CharField(max_length=250, unique=True, null=False)

        def __str__(self):
            return self.name


    class B(m.Model):
        id = m.AutoField(primary_key=True)
        name = m.CharField(max_length=250, unique=True, null=False)
        a = m.ForeignKey(A)

        def __str__(self):
            return self.name


    class C(m.Model):
        id = m.IntegerField(null=False, unique=True, primary_key=True)
        name = m.CharField(max_length=250, unique=True, null=False)
        bs = m.ManyToManyField(B, through='D')

        def __str__(self):
            return '%d, %s, (%s), (%s)' % (
                self.id,
                self.name, 
                ', '.join(b.name for b in self.bs.all()), 
                ', '.join(b.a.name for b in self.bs.all()))
                )


    class D(m.Model):
        c = m.ForeignKey(C)
        b = m.ForeignKey(B)

        class Meta:
            unique_together = ('c', 'b')

Джанго-tables2 от модели C:

class CTable(tables.Table):

    class Meta:
         model = C

Просмотры:

def C(request):
    data = C.objects.all()
    c_table = t.CTable(data)
    return render(request, 'c.html', {'c_table': c_table})

и в c.html:

...
    {% render_table c_table %}
...

Я получаю таблицу с двумя столбцами (ID, имя) вместо четырех (идентификатор, имя, b.name, baname). Как получить недостающие столбцы многие ко многим? Извините за мой ужасный английский.

1 ответы

5

Добавьте метод свойства в модели и сделать это с помощью класса таблицы, то есть:

класс модели

class C(m.Model):
    id = m.IntegerField(null=False, unique=True, primary_key=True)
    name = m.CharField(max_length=250, unique=True, null=False)
    bs = m.ManyToManyField(B, through='D')

    def __str__(self):
        return '%d, %s, (%s), (%s)' % (
            self.id,
            self.name, 
            ', '.join(b.name for b in self.bs.all()), 
            ', '.join(b.a.name for b in self.bs.all()))
            )

   @property
   def all_bs(self):
      return ', '.join([x.name for x in self.bs.all()])

класс Таблица

class CTable(tables.Table):

    class Meta:
         model = C
         fields = ('a', 'b', 'all_bs')