我重写sale.order模型,并在功能上_amount_all一些变化并在python中的文件my_module中使用my_function进行一些操作之后,将一列amount_my_total添加到股票信息。
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"),
}
您是否尝试过'self.amount_total'?如果它不起作用,也许你必须重载函数_amount_all来获取值更新 – ChesuCR
如何覆盖函数? –