Django запрос количества вхождений символа в поле CharField
У меня есть поле CharField, которое содержит пути, например:
zero/one/two/three
, или root/usr/et_cetera
Количество разделителей (здесь /
) дает нам глубину "узла" в пути, поэтому в предыдущем примере three
имеет глубину 3.
В python я мог бы написать 'zero/one/two'.count('/')
, но мне интересно, как это сделать в запросе Django.
Я ищу что-то вроде следующего:
# Hypothetical code, does not work
Model.object.annotate(depth=CountChr('path', V('/'))).filter(depth=2)
Я не могу найти функцию, которая делает это, в документации по django.
Это должно быть возможно путем замены всех вхождений искомого символа на пустую строку, нахождения длины с замененными символами и вычитания ее из исходной длины
from django.db.models.functions import Replace, Length
from django.db.models import Value
Model.objects.annotate(depth=Length('path') - Length(Replace('path', Value('/')))).filter(depth__lt=2 + 1)
Вы можете использовать регекс-фильтр Django.
https://docs.djangoproject.com/en/4.0/ref/models/querysets/#regex
Вы можете попробовать это или подобное этому
Model.object.filter(path__regex=r'\w*\\w{2}')
Попробуйте различные шаблоны regex