繁体   English   中英

odoo - 从many2one字段中获取价值

[英]odoo - get value from many2one field

我的代码:

class SaleOrder(osv.Model):
    _inherit = 'sale.order'

    _columns = {
        'xx_delivery_date': fields.date(string='Delivery date'),
        'xx_payment_method': fields.many2one('xx.payment.method',
                                             string='Payment method'),
        'xx_insurance_type': fields.many2one('xx.insurance.type', string='Insurance')
    }

    def _amount_insurance(self, cr, uid, val1, context=None):
        val = 0.0
        insurance_chosen = self.pool.get('xx.insurance.type').browse(cr, uid, insurance_percentage.id,context=context)
        val = val1*insurance_chosen/100
        return val

class InsuranceType(osv.Model):
    _name='xx.insurance.type'

    _columns = {
        'name' : fields.char(size=128, string = 'Name'),
        'sale_ids': fields.one2many('sale.order', 'xx_insurance_type', string = 'Sale orders'),
        'insurance_percentage' : fields.float('Insurance cost in %')
    }

我试图从'insurance_percentage'字段中获取浮动并将此百分比添加到val1。

目前我的代码导致了

'Global name insurance_percentage not defined,

所以我必须以某种方式告诉函数从InsuranceType类中获取变量,但我不知道如何做到这一点。

对于many2one字段,我们需要首先获取该记录的id,然后使用id浏览该记录并从中获取欲望值。

试试这段代码:

def _amount_insurance(self, cr, uid, ids, val1, context=None):
    val = 0.0
    for insurance in self.browse(cr, uid, ids,context=context):
        if insurance.xx_insurance_type:
            val = (val1 * (insurance.xx_insurance_type.insurance_percentage/100))
    return val

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM