当前位置: 首页>>代码示例 >>用法及示例精选 >>正文


Python Django StrIndex用法及代码示例


本文介绍 django.db.models.functions.StrIndex 的用法。

声明

class StrIndex(string, substring, **extra)

返回一个正整数,对应于 substringstring 内第一次出现的 1 索引位置,如果未找到 substring,则返回 0。

使用示例:

>>> from django.db.models import Value as V
>>> from django.db.models.functions import StrIndex
>>> Author.objects.create(name='Margaret Smith')
>>> Author.objects.create(name='Smith, Margaret')
>>> Author.objects.create(name='Margaret Jackson')
>>> Author.objects.filter(name='Margaret Jackson').annotate(
...     smith_index=StrIndex('name', V('Smith'))
... ).get().smith_index
0
>>> authors = Author.objects.annotate(
...    smith_index=StrIndex('name', V('Smith'))
... ).filter(smith_index__gt=0)
<QuerySet [<Author: Margaret Smith>, <Author: Smith, Margaret>]>

警告

在 MySQL 中,数据库表的排序规则确定字符串比较(例如该函数的expressionsubstring)是否区分大小写。默认情况下,比较不区分大小写。

相关用法


注:本文由纯净天空筛选整理自djangoproject.com大神的英文原创作品 django.db.models.functions.StrIndex。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。