odoo在底部显示制定字段合计and汇总时显示合计

来源:互联网 发布:单片机汇编语言入门 编辑:程序博客网 时间:2024/05/02 12:20

  1. odoo的tree视图底部显示合计
tree 视图,底部显示指定字段合计数 ,视图中字段定义上在sum,
取自sale.view_order_tree 销售订单 tree 视图
   
<field name="amount_total" sum="Total Tax Included"/>



  1. odoo使用group by分组时显示字段合计
来自:http://stackoverflow.com/questions/27536186/how-to-sum-other-columns-when-using-group-by-in-a-tree-view

方法是重写read_group方法

The key is to overwrite the read_group method of the class:
class your_class(osv.osv):    # ...            def read_group(self, cr, uid, domain, fields, groupby, offset=0, limit=None, context=None, orderby=False, lazy=True):        res = super(your_class, self).read_group(cr, uid, domain, fields, groupby, offset, limit=limit, context=context, orderby=orderby, lazy=lazy)        if 'amount_pending' in fields:            for line in res:                if '__domain' in line:                    lines = self.search(cr, uid, line['__domain'], context=context)                    pending_value = 0.0                    for current_account in self.browse(cr, uid, lines, context=context):                        pending_value += current_account.amount_pending                    line['amount_pending'] = pending_value        if 'amount_payed' in fields:            for line in res:                if '__domain' in line:                    lines = self.search(cr, uid, line['__domain'], context=context)                    payed_value = 0.0                    for current_account in self.browse(cr, uid, lines, context=context):                        payed_value += current_account.amount_payed                    line['amount_payed'] = payed_value        return res

If you want, for example, remove the sum of a column in the group by, you can do something like this:

class your_class(osv.osv):    # ...         def read_group(self, cr, uid, domain, fields, groupby, offset=0, limit=None, context=None, orderby=False, lazy=True):        if 'column' in fields:            fields.remove('column')        return super(your_class, self).read_group(cr, uid, domain, fields, groupby, offset, limit=limit, context=context, orderby=orderby, lazy=lazy):


0 0