0

我需要一个搜索框,模型的一个字段有一个 M2M 字段。我必须说它有效,但仅在我查找 M2M 字段的 id 时才有效,而不是名称。我的模型:

class Specialities(models.Model):
    name = models.CharField(max_length=100)

    def __str__(self):
        return self.name


 class Profile(models.Model):
        user = models.OneToOneField(User)
        name = models.CharField(max_length=200)
        specialities = models.ManyToManyField(Specialities)

        def __str__(self):
            return self.name

而我的观点:

class SearchView(TemplateView):
    template_name = 'contadores/search.html'

    def post(self,request,*args,**kwargs):
        buscar = request.POST['buscar']
        contadores = Profile.objects.filter(specialities=buscar)
        ctx = {'contadores':contadores}
        return render_to_response('contadores/resultados.html',ctx,context_instance=RequestContext(request))

“contadores”中的查询集工作正常,但正如我之前所说,如果我在搜索框中查找单词,搜索框只接收 M2M 字段的 django 说:int() 以 10 为底的无效文字: 'niif'我知道原因,但是如何将与 Specialties 模型关联的 M2M 字段的单词而不是 id 传递到搜索框?

4

2 回答 2

0

试试这样:

 buscar = Specialities.objects.filter(name__iexact = request.POST['buscar'])
 if buscar.exists():
     contadores = Profile.objects.filter(specialities=buscar[0])
于 2015-01-07T06:18:17.547 回答
0

您可以做的是按相关表搜索,如下所示:

contadores = Profile.objects.filter(specialities__name__iexact = request.POST['buscar'])
于 2015-01-07T06:22:29.817 回答