how can I solve this ERROR: Expected singleton candidat(1,2,3,4)

how can I solve this ERROR: Expected singleton candidat(1,2,3,4)

def _get_index_content(self, cr, uid, ids, fields, args, context=None):
    res = dict.fromkeys(ids, '')
    Attachment = self.pool.get('ir.attachment')
    applicant_ids = self.pool.get('hr.applicant').search(cr, uid, [('email_from', '=', self.browse(cr, uid, ids, context=context).email_candidat)], context=context)
    attachment_ids = Attachment.search(cr, uid, ['|', '&', ('res_model', '=', 'candidat.base'), ('res_id', 'in', ids), '&', ('res_model', '=', 'hr.applicant'), ('res_id', 'in', applicant_ids)], context=context)
    for attachment in Attachment.browse(cr, uid, attachment_ids, context=context):
        res[attachment.res_id] += attachment.index_content or ''
    return res                  


def _content_search(self, cr, user, obj, name, args, context=None):
    record_ids = set()
    Attachment = self.pool.get('ir.attachment')
    ids = obj.search(cr, uid, [])
    applicant_ids = self.pool.get('hr.applicant').search(cr, user, [('email_from', '=', self.browse(cr, user, ids, context=context).email_candidat)], context=context)
    args = ['&'] + args + ['|', '&', ('res_model', '=', 'candidat.base'), ('res_id', 'in', ids), '&', ('res_model', '=', 'hr.applicant'), ('res_id', 'in', applicant_ids)]
    att_ids = Attachment.search(cr, user, args, context=context)
    record_ids = set(att.res_id for att in Attachment.browse(cr, user, att_ids, context=context))
    return [('id', 'in', list(record_ids))]

'index_content': fields.function(_get_index_content,fnct_search=_content_search, string='Index Content', type="text" ),

我得到了 Expected singleton candidat.base(1,2,3,4) 作为错误。

applicant_ids = self.pool.get('hr.applicant').search(cr, user, [('email_from', '=', self.browse(cr, user, ids, context=context).email_candidat)], context=context)

如果 ids 是 2 个或更多 ID 的列表,则将不起作用。浏览将获得一个包含 2 个条目的 RecordSet,您不能在其中调用 email_candidat.

等字段值

尝试搜索所有电子邮件地址,例如:

applicant_ids = self.pool.get('hr.applicant').search(cr, user, [('email_from', 'in', [x.email_candidat for x in self.browse(cr, user, ids, context=context)])], context=context)

也许可以使用更多行来使代码更具可读性。