12

文档说:

在表由模型支持的情况下,数据库将处理排序。如果不是这种情况,则使用 Python cmp 函数,并在比较不同类型时使用以下机制作为后备: ...

但这可能在由模型支持的表中在自定义列上吗?例如

class MyModel(models.Model):
    x = models.IntegerField()
    y = models.IntegerField()

    def z(self):
        return x+y

class MyTable(tables.Table):
    z = tables.Column()
    class Meta:
        model = MyModel

当我尝试这样的事情时,该列显示 OK,但是当我单击列标题进行排序时,我收到此错误:

渲染时捕获 FieldError:无法将关键字 u'z' 解析为字段。选择是:...

显然这是因为在数据库表中没有找到 z。

有没有解决的办法?

4

1 回答 1

4

如果您对没有数据库列的属性进行排序,则不能使用查询集。不过,您可以将列表传递给您的表。

假设您的 models.py 看起来像这样:

from django.db import models

class MyModel(models.Model):
    def foo(self):
        return something_complex()

您可以拥有如下所示的 tables.py:

import django_tables2 as tables
from .models import MyModel

class MyModelTable(tables.Table):
    foo = tables.Column()

    class Meta:
        model = MyModel

然后在你的views.py中:

from django_tables2.config import RequestConfig
from django.core.paginator import InvalidPage
from django.shortcuts import render

def view_my_models(request):
    # use a list so django_tables2 sorts in memory
    my_models = list(MyModel.objects.all())

    my_models_table = MyModelTable(my_models)
    RequestConfig(request).configure(my_models_table)

    try:
        page_number = int(request.GET.get('page'))
    except (ValueError, TypeError):
        page_number = 1

    try:
        my_models_table.paginate(page=page_number, per_page=10)
    except InvalidPage:
        my_models_table.paginate(page=1, per_page=10)

    template_vars = {'table': my_models_table}
    return render(response, "view_my_models.html", template_vars)

还有一张讨论这个问题的公开票

于 2013-08-13T14:10:25.983 回答