python - Django-tables2 列总数

标签 python django django-tables2

我正在尝试使用此 documentation 对列中的所有值求和,但页脚未显示。我是不是漏了什么?

模型.py

class Mokejimai(models.Model):
    id = models.AutoField(primary_key=True)
    nr = models.IntegerField(verbose_name='Mok. Nr.')
    data = models.DateField(verbose_name='Kada sumokėjo')
    suma = models.FloatField(verbose_name='Sumokėta suma')
    skola_pagal_agnum = models.FloatField(verbose_name='Skola pagal Agnum')
    date_entered = models.DateTimeField(auto_now_add=True, auto_now=False, verbose_name='Apmokėjimas įvestas')
    date_modified = models.DateTimeField(auto_now_add=False, auto_now=True, blank=True, null=True)
    imone = models.ForeignKey(Imones, models.DO_NOTHING, verbose_name='Įmonė')
    sask = models.ForeignKey(Saskaitos, blank=True, null=True, verbose_name='Sąskaita')
    user = models.ForeignKey(User, models.DO_NOTHING, default=settings.AUTH_USER_MODEL)

表格.py

class MokejimaiTable(tables.Table):
    suma = tables.Column(footer=lambda table: sum(x['suma'] for x in table.data))

    class Meta:
        model = Mokejimai
        attrs = {"class": "paleblue"}
        fields = ('id', 'imone', 'sask', 'nr', 'suma', 'skola_pagal_agnum', 'data', 'date_entered')

最佳答案

您的屏幕截图显示 django-tables2 正确地假定您的表上有页脚(耶!)但似乎没有从 lambda 返回任何内容。你可以尝试用这样的东西替换它,看看发生了什么:

def suma_footer(table):
    try:
        s = sum(x['suma'] for x in table.data)
        print 'total:', s
    except Exception e:
        print str(e)
        raise

    return s


class MokejimaiTable(tables.Table):
    suma = tables.Column(footer=suma_footer)

    class Meta:
        model = Mokejimai
        attrs = {"class": "paleblue"}
        fields = ('id', 'imone', 'sask', 'nr', 'suma', 'skola_pagal_agnum', 'data', 'date_entered')

如果在计算总和时出现问题,您应该会看到打印出一个异常,如果计算了一个值,您应该会看到打印出“total:”。

关于python - Django-tables2 列总数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/37701875/

相关文章:

python - 基于三列的重复项

python - 在 Python 中对具有非数字索引的多维字典进行排序时出现问题

python - Pandas Groupby 在不同轴上使用多个标准

Django while 循环

python - django-tables2 中带有 render_* 方法的列不起作用

python - 如何在 django-tables2 中调用非模型字段

python - 从 Pandas 数据框和 reshape 表中删除 NaN 值

python - 从 Django 路由到 Angular 路由

python - 在切片之前评估 Django 查询集对象(或不是)的最佳实践方法?

python - Django:django-tables2 分页和过滤