Django-filter,如何进行多字段搜索?(使用 django 过滤器!)

Med*_*vin 11 python django django-filter

如何使用 Django-filter 从模型中进行多个字段搜索,例如:

class Location(models.Model):
    loc = models.CharField(max_length=100, blank=True)
    loc_mansioned = models.CharField(max_length=100, blank=True)
    loc_country = models.CharField(max_length=100, blank=True)
    loc_modern = models.CharField(max_length=100, blank=True)
Run Code Online (Sandbox Code Playgroud)

我的网站上需要一个输入字段,可以搜索位置模型的所有字段

Dal*_*tor 22

您可能可以创建一个自定义过滤器并执行以下操作:

from django.db.models import Q
import django_filters


class LocationFilter(django_filters.FilterSet):
    q = django_filters.CharFilter(method='my_custom_filter',label="Search")

    class Meta:
        model = Location
        fields = ['q']

    def my_custom_filter(self, queryset, name, value):
        return Location.objects.filter(
            Q(loc__icontains=value) | Q(loc_mansioned__icontains=value) | Q(loc_country__icontains=value) | Q(loc_modern__icontains=value)
        )
Run Code Online (Sandbox Code Playgroud)

这将按这些字段中的任何一个进行过滤。你可以用icontains你想要的任何东西替换。