Django在fitler过滤不等于的条件

提问

django 在API接口fitler的时候如何过滤 category 不等于6的

解答

为了在AoYuStudentFilter中设置过滤category不等于6的条件,需要使用django_filters库中的exclude方法。不过直接在FilterSet中使用exclude可能不那么直观,因为FilterSet主要设计用来包含符合条件的结果,而不是排除它们。可以通过定义自定义过滤方法来实现这一点。

已经安装了django_filters库并正确配置了Django项目以使用它。

可以通过以下方式在你的FilterSet类中添加一个自定义方法来实现category不等于6的过滤:

python 复制代码
from django_filters import rest_framework as filters
from .models import MyModel

class AoYuStudentFilter(filters.FilterSet):
    # 已有的过滤器...
    
    # 添加一个新的过滤器,用于`category`不等于6
    category_not = filters.NumberFilter(method='filter_category_not')
    
    class Meta:
        model = MyModel
        fields = ['name_student', 'id_student', 'voucher_number', 'from_high_school', 'from_university', 'subjects_before', 'subjects_after', 'from_university_major', 'date_admission_daterangeStart', 'date_admission_daterangeEnd', 'create_datetime_daterangeStart', 'create_datetime_daterangeEnd', 'score_total_min', 'score_total_max', 'category_not']
    
    def filter_category_not(self, queryset, name, value):
        """
        自定义过滤方法,排除category等于指定值的记录
        """
        if value is not None:
            return queryset.exclude(category=value)
        return queryset

在这个例子中,category_not过滤器通过指定method='filter_category_not'来引用一个自定义的过滤方法。这个方法接收queryset、字段名称(name)和过滤值(value),并返回一个排除了特定category值的查询集。

当想要过滤category不等于6的记录时,可以在API请求中添加一个参数category_not=6。这样,filter_category_not方法会被调用,并且queryset会被更新为排除category值为6的记录。

MyModel应替换为实际使用的模型名称,并确保category字段存在于该模型中。此外fields列表中的其它字段名应该根据你的模型实际字段进行相应的调整。

相关推荐
leegong2311112 分钟前
如何备考PostgreSQL中级认证
数据库·postgresql
赵渝强老师17 分钟前
【赵渝强老师】什么是NoSQL数据库?
数据库·nosql
ifanatic30 分钟前
[每周一更]-(第131期):Go并发协程总结篇
开发语言·数据库·golang
csdn56597385037 分钟前
SQL分类与数据类型整理
数据库·sql·oracle
MrZhangBaby1 小时前
SQL-leetcode-584. 寻找用户推荐人
数据库·sql·leetcode
骚戴1 小时前
Navicat连接Oracle报错:ORA-12638: 身份证明检索失败的解决方法
数据库·oracle
被瞧不起的神1 小时前
软件系统分析与设计综合实践-家庭维修服务系统小程序(代码见附录,私发)
django
经常喝假酒的胡小臣1 小时前
Django学习笔记之数据库(一)
数据库·学习·django
Elastic 中国社区官方博客2 小时前
Elasticsarch:使用全文搜索在 ES|QL 中进行过滤 - 8.17
大数据·数据库·sql·elasticsearch·搜索引擎·全文检索
凉秋girl2 小时前
Redis常见知识点
数据库·redis·缓存