Django фильтр для NOT IN как lookup_expr

Мы можем сделать фильтр django с выражением "in", отправляющим строку, разделенную запятыми. Например

import django_filters

class NumberInFilter(django_filters.BaseInFilter, django_filters.NumberFilter):
    pass

class BookFilter(django_filters.FilterSet):
    author = NumberInFilter(field_name="author__id", lookup_expr="in")

Однако я искал способ отправить данные запроса, разделенные запятыми, и получить ответ, в котором нет данных запроса. что-то вроде

class BookFilter(django_filters.FilterSet):
    author = NumberInFilter(field_name="author__id", lookup_expr="not_in")

Определенно нет ничего похожего на "not_in". Подскажите, пожалуйста, решение, как этого добиться?

Я не уверен, что в django-filters есть простой встроенный метод для выполнения экслюзивного поиска. Однако вы можете сделать это довольно легко с помощью пользовательского метода в вашем классе filterset с .exclude() :

class BookFilter(django_filters.FilterSet):
    author = django_filters.NumberFilter(method='filter_author')

    def filter_author(self, queryset, name, value):
        return queryset.exclude(author_id__in=value)

Просто хотел добавить то, что я наконец-то получил,

class BookFilter(django_filters.FilterSet):
    author = django_filters.NumberFilter(method='filter_author')

    def filter_author(self, queryset, name, value):
        if value:
            return queryset.exclude(author__id__in=value.split(','))
        return queryset
Вернуться на верх