使用Substr和负值在注释中切片查询结果字符串字段

问题描述 投票:1回答:1

我正在尝试使用this post中给出的方法对字段的最后两个字符进行切片并对其进行注释以查询结果。就像是:

Person.objects.all()\
.annotate(
    code = Substr('str', 1, -2),
)

一旦我使用负值作为第三个参数,上面的代码返回一个空字符串。我怎样才能做到这一点?

python django substr annotate
1个回答
1
投票

首先需要为正索引注释一个字段。然后你可以使用Substr如下:

Person.objects.annotate(
    PositiveIndex=ExpressionWrapper(Length('str') - 1, output_field=CharField()),
    code=Substr('str', F('PositiveIndex'))
).values('code')
© www.soinside.com 2019 - 2024. All rights reserved.