<p>我覆盖了销售订单在python中的file my_module中使用my_函数进行一些操作后,对函数_amount_all进行一些更改,并在股票信息中添加一列amount_my_total。在</p>
<pre><code>class sale_order(osv.Model):
_inherit = 'sale.order'
_name = 'sale.order'
_description = ""
def _amount_all_text(self, cr, uid, ids, field_name, arg, context=None):
return self._amount_all(cr, uid, ids, field_name, arg, context=context)
def _amount_all(self, cr, uid, ids, field_name, arg, context=None):
cur_obj = self.pool.get('res.currency')
res = {}
for order in self.browse(cr, uid, ids, context=context):
res[order.id] = {
'amount_untaxed': 0.0,
'amount_tax': 0.0,
'amount_total': 0.0,
'amount_my_total':'my default value when total = 0'
}
val = val1 = 0.0
cur = order.pricelist_id.currency_id
for line in order.order_line:
val1 += line.price_subtotal
val += self._amount_line_tax(cr, uid, line, context=context)
res[order.id]['amount_tax'] = cur_obj.round(cr, uid, cur, val)
res[order.id]['amount_untaxed'] = cur_obj.round(cr, uid, cur, val1)
res[order.id]['amount_total'] = res[order.id]['amount_untaxed'] + res[order.id]['amount_tax']
res[order.id]['amount_my_total'] = my_module.my_function(res[order.id]['amount_total'])
return res
_columns = {
'amount_my_total': fields.function(_amount_all_text, string='my string', type='text',store={
'sale.order': (lambda self, cr, uid, ids, c={}: ids, ['order_line'], 10),
},
multi='sums', help="my total help message"),
}
</code></pre>