콘텐츠로 건너뛰기
메뉴
커뮤니티에 참여하려면 회원 가입을 하시기 바랍니다.
신고된 질문입니다
1 회신
5958 화면

I have a computed field that computes every time I refresh the page. I tried using api.depends but it computes twice, once when I fill in the dependent field and once when I save. I want to compute the once then never change it again for that record. How can I do that? I have included the code below 



    

    product_name = fields.Many2one('product.info', string='Product')
    units_sold = fields.Integer(string='Units Sold', required = True)    
    current_stock = fields.Integer("Today's Stock", compute='_compute_stock', store=True)   
    units_entered = fields.Integer('Stock Entered')     @api.depends('units_sold')   
    def _compute_stock(self):       
        for rec in self:            
            if rec.units_sold > 0 and rec.units_entered > 0:               
                rec.current_stock= rec.product_name.product_quantity - rec.units_sold + rec.units_entered           
            elif rec.units_sold > 0 and rec.units_entered == 0:               
                rec.current_stock= rec.product_name.product_quantity - rec.units_sold           
            elif rec.units_sold == 0 and rec.units_entered > 0:               
                rec.current_stock= rec.product_name.product_quantity + rec.units_entered           
            rec.product_name.product_quantity = rec.current_stock
아바타
취소

Since you are using store=True then the computed method will be called only if one of the fields mentioned in depend api changed.

베스트 답변

Hello,

Try below code:

@api.depends('units_sold')
def _compute_stock(self):
for rec in self:
current_stock = 0.0
if rec.units_sold > 0 and rec.units_entered > 0:
current_stock= rec.product_name.product_quantity - rec.units_sold + rec.units_entered
elif rec.units_sold > 0 and rec.units_entered == 0:
current_stock= rec.product_name.product_quantity - rec.units_sold
elif rec.units_sold == 0 and rec.units_entered > 0:
current_stock= rec.product_name.product_quantity + rec.units_entered
rec.current_stock = current_stock
rec.product_name.product_quantity = current_stock


아바타
취소
관련 게시물 답글 화면 활동
1
7월 25
6663
1
7월 21
4335
2
5월 24
11524
1
4월 21
3899
1
4월 24
3474