one2many字段获取行号

时间:2019-04-09 08:28:09

标签: odoo-11 one2many

我有一个模块,其中包含一个文件。

在此o2m字段中创建数据行时,我想向其添加行号。

我尝试了一些在论坛中找到的方法,例如this link

但是由于我没有名为_onchange_partner_id()的函数,所以我不知道如何使用它。

this link

但似乎我感觉不太舒服。

class YcWeight(models.Model):

    _name = "yc.weight"
    customer_detail_ids = fields.One2many("yc.weight.details", "name", "customer details")

class YcWeightDetails(models.Model):
    _name = "yc.weight.details"

    name = fields.Many2one("yc.weight", "weight detail list", ondelete="cascade")
    no = fields.Integer("row number")

“ no”是我要显示行数的字段。 我的问题是:

如何获取行数?

由于onchage装饰函数无法从db获取数据。

1 个答案:

答案 0 :(得分:0)

我自己找到了一个解决方案,这很简单:

使用取决于装饰器。

class YcWeightDetails(models.Model):
    _name = "yc.weight.details"

    name = fields.Many2one("yc.weight", "weight detail list", ondelete="cascade")
    no = fields.Integer("row number")
    compuute_no = fields.Integer("invisible field", compute= "_get_row_no")

创建一个字段“ compuute_no”进行计算。

    @api.depends("compuute_no")
    def _get_row_no(self):
        if self.ids:
            count =1
            for rec in self:
                weight_id = self.env['yc.weight.details'].search([('id','=', rec.id)])
                weight_id.write({'no': count})
                count+=1

或覆盖创建方法

@api.model
    def create(self, vals):
        main_key = self.env["yc.weight"].search([], order="id desc", limit=1).id
        item_key = vals["name"]
        if item_key and main_key == item_key:
            number = len(self.env["yc.weight.details"].search([("name", "=", item_key)]))
            vals.update({"no": number + 1})
            return super(YcWeightDetails, self).create(vals)

希望它可以为您提供帮助。