我使用jasper在openerp
中创建了2个报告。但是我对这两份报告使用了相同的解析器,第一份报告是“详细报告”,第二份报告是“摘要”。在追加到结果列表中的词典(命名数据)中,有关键日期,发票,借记和贷记。对于详细的报告,我只需要从account.move.line
得到这些值。但是对于汇总报告,应该只有一行包含相同发票号的帐户移动行。那是我需要添加具有相同发票号码的帐户移动行的借方和贷方,并将其显示为一行,我如何在Python中执行此操作。例如,结果列表是如何基于另一个值在Python字典中添加(总和)两个值?
[{'invoice':1,'debit':10,'credit':10},
{'name':'b','invoice':2,'debit':10,'credit':18},
{'invoice':1,'debit':10,'credit':10}]
和我需要的是
[{'invoice':1,'debit':20,'credit':20},
{'invoice':2,'debit':10,'credit':18}]
编辑: 代码是
move_line_ids = move_line_pool.search(cr, uid, domain, context=context)
print 'move_line_ids', len(move_line_ids)
for move_line in move_line_pool.browse(cr, uid, move_line_ids, context=context):
group_by = grp = grp_acc = ''
debit = credit = bal = 0.0
if move_line.debit > 0.0:
debit = move_line.amount_residual
elif move_line.credit > 0.0:
credit = move_line.amount_residual
bal = debit - credit
if form_group_by == 'group_account_code':
group_by = 'ACCOUNT CODE : '
grp = move_line.account_id.code or ''
grp_acc = move_line.account_id.name or ''
elif form_group_by == 'group_order_no':
group_by = 'ORDER : '
grp = move_line.sale_id.name or ''
else:
group_by = 'INVOICE : '
grp = move_line.invoice.number or ''
date = dt.strptime(str(move_line.date), '%Y-%m-%d').strftime('%d-%m-%Y')
data = {
'period': period,
'date': date,
'company': company or '',
'so': move_line.sale_id.name or '',
'invoice': move_line.invoice.number or '',
'po': '',
'status': '',
'ref': move_line.move_id.name or '',
'debit': debit,
'credit': credit,
'bal': bal,
'fc': '',
'f_amt': '',
'trx': move_line.journal_id.code or '',
'account': move_line.account_id.name or '',
'account_code': move_line.account_id.code or '',
'acc_range': acc_range,
'group_by': group_by,
'grp': grp,
'grp_acc': grp_acc,
}
result.append(data)
if form_group_by == 'group_account_code':
result = sorted(result, key=lambda k: k['account_code'])
elif form_group_by == 'group_order_no':
result = sorted(result, key=lambda k: k['so'])
else:
result = sorted(result, key=lambda k: k['invoice'])
return result
只考虑键invoice,debit and credit
在字典中,其他人如果发票相同,则不需要更新。
它肯定可以使用Python来完成,但我认为这是最好能够通过SQL GROUPBY /总和来完成。请显示一些代码,了解如何生成第一个输出。 – alko
@alko我已经更新了这个问题.. –