0

我在一个类中有两个字段,在第三个字段中我需要之前声明的两个字段的乘法结果。

例如:

_columns = {
            'Item' : fields.integer('Items'),
            'Fecha': fields.date('Fecha del Documento', required=True, select=True),
            'Codigo Arancelario' : fields.integer('Codigo Arancelario'),
            'Descripcion Arancelaria' : fields.char('Descripcion Arancelaria', size=42, required = True, translate = True), 
            'Especificaciones Tecnicas' : fields.char('Especificaciones Tecnicas', size=60, required = True, translate = True), 
            'Cantidad' : fields.float('Cantidad'), 'Unidad de Medida': fields.many2one('product.uom', 'Unidad de Medida'),
            'Precio Unitario Declarado' : fields.float('Precio Unitario Declarado'), 'Moneda' : fields.many2one('res.currency', 'Moneda'),
            'Valor En Divisas' : Result of the multiplication of 'Precio Unitario Declarado' * 'Cantidad',
            'notas' : fields.text('Notas'),
            }

我应该使用函数字段进行如此简单的计算吗?

有没有更简单的方法来实现这一点?

4

4 回答 4

5

函数字段将是进行此类操作的不错选择。这是使用功能字段将两个字段相乘的示例代码。

def multi_a_b(self, cr, uid, ids, name, arg, context=None):
    res = {}
    for record in self.browse(cr, uid, ids,context):
        res[record.id] = record.field_a * record.field_b
    return res

_columns = {
    'field_a': fields.integer('A'),
    'field_b': fields.integer('B'),
    'field_c': fields.function(multi_a_b, type='integer', 'C'),
}
于 2013-04-02T05:06:57.070 回答
1

您需要结合这些答案。

首先将 c4 定义为 user1576199 的答案中指定的功能字段,然后创建 Atul 的答案中定义的 on_change 函数;

def onchange_value(self, cr, uid, ids, c1 = 0.0, c2 = 0.0, c3 = 0.0, context = None):
     return {'value': {'c4': c1 + c2 + c3}}

但是,将 on_change 放在 c1 到 c3 的值上,而不是 c4,就像这样......

 <field name="c1" on_change="onchange_value(c1, c2, c3, context) />
 <field name="c2" on_change="onchange_value(c1, c2, c3, context)/>
 <field name="c3" on_change="onchange_value(c1, c2, c3, context)/>
 <field name="c4" />

c4 是一个功能字段,但您仍然可以在 on_change value 子句中为其他字段返回它,屏幕上的值将被刷新,但不会存储在数据库中,除非您将 store = True 添加到 c4 字段定义。

如果用户更改了 c1、c2 或 c3 字段中的任何一个,将调用 on_change 方法并重新计算总计并在显示屏上刷新。

于 2014-01-02T07:49:02.050 回答
1

这是可能的解决方案

from osv import osv, fields

def multi_price_qty(self, cr, uid, ids, name, arg, context=None):
    res = {}
    for product in self.browse(cr, uid, ids,context):
        res[product.id] = product.price * product.qty
    return res

class abs_product(osv.Model):
    _name = "abs.product"
    _columns = {
    'code': fields.char('Code', size=32),
    'description': fields.char('Description', size=64),
    'sizeunit': fields.char('Size /Unit', size=32),
    'qty': fields.integer('Quantity', size=32),
    'price': fields.integer('Price'),
    'pullout': fields.char('Pull-Out', size=32),
    'return': fields.char('Return', size=32),
    'offtake': fields.char('Offtake', size=32),
    'weeksales': fields.char('Weekly Sales', size=32),
    'date': fields.date('Date'),
    'totalprice': fields.function(multi_price_qty, type='integer', 'Total Price'),
    }
abs_product()
于 2014-03-08T17:37:42.620 回答
0

我认为函数字段对于这种类型的计算是可以的。

或者您可以放置​​一个按钮的另一种方式,在按钮单击时将这两个字段值相乘。

于 2013-04-02T04:34:26.443 回答