Odoo默认情况下,对于产品分类的搜索只能匹配到最末一级的分类,然而在实际的实施过程中,会有很多种情况需要搜索分来的父级乃至顶级,这种情况下就需要我们通过复写默认的name_search方法来达到这种目的了。
代码采用v8 api的写法,v7的请自行转换。
@api.model def name_search(self,name='',args=None,operator='ilike',limit=100): categroies = self.search([('name',operator,name)]) categroies = self._search_category(categroies) if len(categroies): print categroies.name_get() return categroies.name_get() return super(product_category,self).name_search(name=name,args=args,operator=operator,limit=limit) @api.model def _search_category(self,categroies): for category in categroies: sub_categories = self.search([('parent_id','=',category.id)]) categroies += self._search_category(sub_categories) return categroies
方法说明:
首先,查找名称为要搜索的分类的全部分类,然后,递归查找所有以找到的分类为父级分类的子分类,并将其用name_get方法返回