如何对字段进行约束

2024-09-25 00:26:59 发布

您现在位置:Python中文网/ 问答频道 /正文

我想对jrestant执行一个约束,返回两个日期之间的天数,该天数也必须为正。
如何对字段进行约束?你知道吗

    def compa_date(self,cr,uid,ids,args,fields,context=None):   
        res = {}
        for self_brow in self.browse(cr,uid,ids,context):

            if self_brow.Date_ouv_pli or self_brow.date_depot:
                date_debut = datetime.strptime(self_brow.Date_ouv_pli,'%Y-%m-%d')
                date_fin = datetime.strptime(self_brow.date_depot,'%Y-%m-%d')
                res[self_brow.id] = (date_debut - date_fin).days                    
        return res

    _columns = {
        'date_depot' : fields.date('Date dépot de soumission'),
        'Date_ouv_pli' : fields.date('Date Ouverture Plis'),
        'jrestant': fields.function(compa_date,string='Jours restant')
    }

    def _check(self, cr, uid, ids, context=None):
        for product in self.read(cr, uid, ids, ['jrestant'], context=context):
            if jrestant < '0' :
                return False
        return True
    _constraints = [(_check, 'Days must be positive', ['jrestant'])]

Tags: selfidsfieldsuiddatereturncontextres
1条回答
网友
1楼 · 发布于 2024-09-25 00:26:59

store设置为True,这样函数字段的值将存储在数据库中,这允许您对其设置约束。你知道吗

'jrestant': fields.function(compa_date, string='Jours restant', store=True)

相关问题 更多 >