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方法返回