我想在sale.order.line中显示分配的每个产品数量。当我有1个销售订单行时,它可以工作,但如果我有更多的销售订单行,则所有产品的数量都相同。但是我的代码很糟糕,因为有超过1次的移动,那么我怎么做才能正确呢?
reserved_qty = fields.Float(string='Reserved Qty', compute='_get_qtys')
@api.depends('order_id.picking_id.move_lines.state')
def _get_qtys(self):
for line in self:
domain = [('id', '=', line.order_id.picking_id.move_lines.id),
('product_id', '=', line.product_id.id)
]
movez = self.env['stock.move'].search(domain)
line.not_fulfiled_qty = line.product_uom_qty - line.qty_delivered
if line.order_id.picking_id:
for picking in line.order_id.picking_id:
for move in picking.move_lines:
if move.state == 'assigned':
line.reserved_qty = movez.product_uom_qty更新:
如果找到了解决方案,它可以正常工作,但仍然有一个问题,可以有超过1个procurement_ids吗?在某些场景下会出现单例错误吗?
@api.depends('order_id.picking_id.move_lines.state')
def _get_qtys(self):
for line in self:
line.not_fulfiled_qty = line.product_uom_qty - line.qty_delivered
if line.order_id.picking_id:
for move in line.procurement_ids.move_ids:
if move.state == 'assigned':
line.reserved_qty = move.product_uom_qty发布于 2018-09-06 19:10:51
即使有更多的采购,也只需更改您的代码来处理这些情况:
for move in line.procurement_ids.mapped('move_ids'):
if move.state == 'assigned':https://stackoverflow.com/questions/52201462
复制相似问题