首页
学习
活动
专区
圈层
工具
发布

python测试开发django-169.过滤器django-filter 入门使用

,希望让我们的用户根据名称、价格或发布日期进行过滤 exact 精准查找,等价于filter(name=xx),对应sql语句 where name='xx'; iexact 使用 like 进行查找,...您可以使用 Django 的__语法遍历“关系路径”来过滤相关模型上的字段。 例如:manufacturer__name。 lookup_expr: 过滤时使用的字段查找。...__可以再次使用Django 的语法来支持查找转换。 例如:year__gte。 字段field_name和字段一起 lookup_expr 代表一个完整的 Django 查找表达式。...使用 Meta.fields 生成过滤器 FilterSet Meta 类提供了一个fields属性,可用于轻松指定多个过滤器,而无需大量代码重复。...过滤器查找类型“精确”是隐式默认值,因此永远不会添加到过滤器名称中。在上面的示例中,发布日期的确切过滤器是`release_date`,而不是`release_date__exact`。

2.6K20
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Django-官网查询部分翻译(1.11版本文档)-QuerySet-字段查找-06

    想要得到这么一小部分对象,我们需要细化(约束)最初的 QuerySet ,增加过滤条件,细化 QuerySet 最常用的两种写法如下: filter(**kwargs) 返回一个符合你给出的查找参数(条件...你可以给 QuerySet 叠加许多许多过滤条件,但是 django 并不会去执行他们,直到 QuerySet 被 evaluated (检查,评估?...使用... .distinct(*fields) 去重 .values(*fields, **expressions*) 过滤字段 .values_list(*fields, flat=False)...WHERE pub_date BETWEEN '2005-01-01' and '2005-03-31'; 日期时间类 日期时间与日期不能混用 允许其他 关系类的字段查找(field-lookups..., 大于小于这样的) 链式拼接 __date # 匹配 datetime 类型字段,会将传入的值转换为日期,然后搭配 关系类的字段查找(field-lookups)进行比较 Entry.objects.filter

    3.2K20

    Django REST Framework-如何使用过滤器

    ;ChoiceFilter:使用选项过滤,可以用于过滤多选字段;DateFilter:使用日期过滤,可以用于过滤日期类型的字段;NumberFilter:使用数字过滤,可以用于过滤数字类型的字段;RangeFilter...:使用范围过滤,可以用于过滤数字、日期等类型的字段。...编写自定义的过滤器可以让你更好地控制过滤逻辑,并且可以使用任何 Django QuerySet 方法来处理过滤器。...我们实现了 filter_queryset 方法来对查询集进行过滤。在这个例子中,我们使用 queryset.filter() 方法过滤出价格大于等于 10 的书籍。...另外,我们还展示了如何编写自定义的过滤器,以便你可以更好地控制过滤逻辑,并使用任何 Django QuerySet 方法来处理过滤器。

    2.6K40

    如何使用Linux命令和工具在Linux系统中根据日期过滤日志文件?

    使用日期过滤日志文件的方法方法一:使用grep命令和日期模式grep命令是一种强大的文本搜索工具,它可以用于在文件中查找匹配的文本行。我们可以使用grep命令结合日期模式来过滤日志文件。...方法二:使用find命令和-newermt选项find命令用于在文件系统中搜索文件和目录。它可以使用-newermt选项来查找在指定日期之后修改过的文件。...方法三:使用rsyslog工具和日期过滤rsyslog是一种用于系统日志处理的强大工具。它支持高级过滤功能,包括根据日期和时间范围过滤日志。...方法四:使用journalctl命令和日期过滤选项journalctl命令是Linux系统上用于查看系统日志的工具。它支持多种过滤选项,包括日期过滤。...本文介绍了四种常用的方法:使用grep命令和日期模式、使用find命令和-newermt选项、使用rsyslog工具和日期过滤以及使用journalctl命令和日期过滤选项。

    6.5K40

    【Elasticsearch专栏 14】深入探索:Elasticsearch使用Logstash的日期过滤器删除旧数据

    其中,Logstash的日期过滤器(Date Filter)能够帮助识别并删除旧数据。在本文中,将详细探讨如何使用Logstash的日期过滤器来删除Elasticsearch中的旧数据。...01 Logstash日期过滤器的工作原理 Logstash的日期过滤器主要用于解析和转换事件中的日期字段。它可以识别各种日期格式,并将这些日期字段转换为统一的格式,以便进行后续的比较和过滤操作。...当处理时间序列数据时,日期过滤器尤其有用。通过配置日期过滤器,可以指定日期字段的名称和格式,然后使用这个字段来比较事件的时间戳与当前时间。...在filter部分,使用date过滤器来解析timestamp字段,并将其转换为统一的日期格式。然后,移除了Logstash自带的@timestamp字段,因为已经有自己的时间戳字段。...05 小结 通过使用Logstash的日期过滤器,可以有效地删除Elasticsearch中的旧数据,从而释放存储空间、提高集群性能,并降低维护成本。

    72310

    从入门到精通Django REST Framework-(五)

    True) )何时使用:使用 queryset 属性:当查询集是固定的,不需要根据请求动态变化使用 get_queryset() 方法:当需要根据请求用户、查询参数等动态调整查询集2....lookup_field = 'slug' # 使用 slug 字段查找 lookup_url_kwarg = 'book_slug' # URL 中的参数名 # URL...(queryset, many=True) return Response(serializer.data)使用示例:精确过滤:/books/?...self.filter_queryset() 应用过滤在 filter_queryset 中,首先调用父类方法应用配置的过滤器然后遍历所有查询参数,检查是否与模型字段匹配对于匹配的参数,构建过滤条件并应用到查询集最后序列化过滤后的查询集并返回响应使用示例假设...和 paginate_queryset())过滤(filter_backends 和 filter_queryset())通过合理使用这些功能,可以大大简化 API 开发工作,提高代码的可维护性和可读性

    51210

    【愚公系列】2022年04月 Python教学课程 74-DRF框架之过滤

    文章目录 一、普通过滤 1.针对当前用户进行筛选 2.针对网址进行筛选 3.针对查询参数进行筛选 二、通用过滤 1.全局设置 2.视图设置 3.简单过滤 4.搜索器过滤 4.1 多字段查找 4.2 多字段查找...4.3 嵌套查找 4.4 参数说明 4.5 自定义过滤器 一、普通过滤 REST 框架的通用列表视图的默认行为是返回模型管理器的整个查询集。...category=clothing&in_stock=True 4.搜索器过滤 4.1 多字段查找 仅当视图具有属性集时,才会应用该类。...search=russell 4.2 多字段查找 还可以使用查找 API 双下划线表示法对 ForeignKey 或 ManyToManyField 执行相关查找: search_fields = ['...username', 'email', 'profile__profession'] 4.3 嵌套查找 对于 JSONField 和 HStoreField 字段,您可以使用相同的双下划线表示法根据数据结构中的嵌套值进行查找

    2.9K30

    django 1.8 官方文档翻译: 2-2-1 执行查询

    QuerySet表示你数据库中取出来的一个对象的集合。它可以含有零个、一个或者多个过滤器,过滤器根据所给的参数限制查询结果的范围。...使用过滤器获取特定对象 all()方法返回的结果集中包含全部对象,但是更普遍的情况是你需要获取完整集合的一个子集。 要创建这样一个子集,需要精炼上面的结果集,增加一些过滤器作为条件。...最后的结果的一个QuerySet,包含所有标题以”word“开头的记录,并且日期是2005年一月,日为当天的值。...第一个 QuerySet 包含大标题以”What”开头的所有记录。第二个则是第一个的子集,用一个附加的条件排除了出版日期 pub_date 是今天的记录。...第三个也是第一个的子集,它只保留出版日期 pub_date 是今天的记录。 最初的 QuerySet (q1) 没有受到筛选的影响。

    5.1K20

    Django学习笔记:QuerySet API

    他的方法全部都是通过Python动态添加的方式,从QuerySet类中拷贝过来的。 所以我们如果想要学习ORM模型的查找操作,必须首先要学会QuerySet上的一些API的使用。...返回新的QuerySet的方法: 在使用QuerySet进行查找操作的时候,可以提供多种操作。比如过滤完后还要根据某个字段进行排序,那么这一系列的操作我们可以通过一个非常流畅的链式调用的方式进行。...: print(sql) 那如果确实是想要在查询的时候指定过滤条件该如何做呢,这时候我们可以使用django.db.models.Prefetch来实现,Prefetch这个可以提前定义好queryset...('='*30) print(sql) defer虽然能过滤字段,但是有些字段是不能过滤的,比如id,即使你过滤了,也会提取出来。...切片操作:有时候我们查找数据,有可能只需要其中的一部分。那么这时候可以使用切片操作来帮我们完成。QuerySet使用切片操作就跟列表使用切片操作是一样的。

    78220

    Django-models & QuerySet API

    django中配置mysql数据库 查询queryset时如果需要选取查询集中的某个子集的字段时, 应该用切片,或者first 选择某个子集对象,这样才能够使用到 子集的字段,直接queryset后选择字段会直接报错...数字,下划线或连字符 CommaSeparatedIntegerField   – 字符串类型,格式必须为逗号分割的数字 UUIDField   uuid类型 DateTimeField     – 日期...+时间格式 YYYY-MM-DD HH:MM[:ss[.uuuuuu]][TZ] DateField   – 日期格式 YYYY-MM-DD TimeField   – 时间格式 HH:MM[:ss[....print(i.name,i.age) ... lily 22 jack 28 beibei 20 hei 1 >>> filter  过滤,返回符合条件的一批对象,列表 >>> Person.objects.filter...school和teacher表里并没有写,但是他们可以通过反向关联,查找到对应的student: >>> School.objects.get(school_name='北大').student_set

    1.7K20

    Django(19)QuerySet API

    示例图如下: 所以我们如果想要学习ORM模型的查找操作,必须首先要学会QuerySet上的一些API的使用 QuerySet 21个常用的API filter filter:将满足条件的数据提取出来...: print(sql) 那如果确实是想要在查询的时候指定过滤条件该如何做呢,这时候我们可以使用django.db.models.Prefetch来实现,Prefetch这个可以提前定义好queryset...,文章的内容我们是不需要的,因此这时候我们就可以使用defer来过滤掉一些字段。...,但是有些字段是不能过滤的,比如id,即使你过滤了,也会提取出来。...切片 切片操作:有时候我们查找数据,有可能只需要其中的一部分。那么这时候可以使用切片操作来帮我们完成。QuerySet使用切片操作就跟列表使用切片操作是一样的。

    91010
    领券