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

Вернуться на верх