0

我想浏览 many2many 字段但收到此错误:

文件“C:\Program Files (x86)\OpenERP 7.0\Server\server\openerp\addons\schoolem\schoolem_dispense_cours.py”,第 39 行,创建 AttributeError:'**browse_record_list' 对象没有属性

heure_cours_dispense_id

这是代码:

class schoolem_dispense_cours(osv.Model):

_name = 'schoolem.dispense_cours'
_columns = {
    'name' : fields.char('Code',required=True,help="Champ automatique"),
    'cours_id' : fields.many2one('schoolem.cours','Nom du Cour',required=True),
    'aca_id' : fields.many2one('schoolem.aca','Annee Academique',required=True),
    'enseignant_id' : fields.many2one('res.users','Enseignant',required=True),
    'salle_de_classe_id' : fields.many2one('schoolem.salle_de_classe','Salle de classe',required=True),
    'heure_cours_id' : fields.many2many('schoolem.heure_cours_dispense','schoolem_dispense_cours_heure_cours_dispense','dispense_cours_id','heure_cours_dispense_id','Heures de cour'),
    #'heure_cours_id' : fields.many2many('schoolem.heure_cours_dispense',required=True),
} 

def create(self, cr, uid, vals, context=None):
        if not vals['heure_cours_id'][0][2]:
            raise osv.except_osv(('Erreur!'), ('Une Programmation doit avoir au moins une heure de cours!'))
        ids = self.search(cr,uid,[('aca_id','=',vals['aca_id'])])
        created_hc = []
        if ids : 
            for id in ids :
                obj_disp_crs = self.pool.get('schoolem.dispense_cours').browse(cr,uid,id)
                created_hc.append(obj_disp_crs.heure_cours_id.heure_cours_dispense_id)
4

1 回答 1

1

在 many2many 字段中,我们可以添加多条记录。因此,如果我们尝试浏览 many2many 字段,我们将获得多条记录或一个浏览列表。您可以实现与以下相同的功能:

def create(self, cr, uid, vals, context=None):
    ids = self.search(cr,uid,[('aca_id','=',vals['aca_id'])], context=context)
    created_hc = []
    for obj_disp_crs in self.browse(cr, uid, ids, context=context):
        created_hc.extend([x.heure_cours_dispense_id for x in obj_disp_crs.heure_cours_id])

但是这段代码还有另一个问题,因为在执行这个创建函数之后,将创建一个满足条件 aca_id = vals['aca_id'] 的新记录。但是你不会在搜索条件下得到这个记录id

ids = self.search(cr,uid,[('aca_id','=',vals['aca_id'])], context=context)

因为这个记录是在这个创建函数执行之后创建的。因此,为了也获得此 id,您需要先调用 create 函数的 super,然后执行进一步的功能。

于 2013-11-03T05:10:52.507 回答