Как отфильтровать теги taggit с полями связанных элементов, используя Django ORM?
У меня есть модель, в которой я использую django-taggit TaggableManager:
from django.db import models
from model_utils import Choices
from taggit_autosuggest.managers import TaggableManager
LANGUAGE_CHOICES = Choices(
('de', 'Allemand - Deutch'),
('en', 'Anglais - English'),
('es', 'Espagnol - Español'),
('fr', 'Français'),
('it', 'Italien - Italiano'),
('jp', 'Japonais - 日本語'),
('ko', 'Coréen - 한국어'),
('pt', 'Portugais - Português'),
('th', 'Thaï - ไทย'),
('vi', 'Vietnamien - Tiếng Việt'),
('zh', 'Chinois - 中文'),
)
class Recipe(models.Model):
language = language = models.CharField(
max_length=5,
choices=LANGUAGE_CHOICES,
default=LANGUAGE_CHOICES.en
)
tags = tags = TaggableManager(
help_text="Use tab to add a new term.",
blank=True
)
Как я могу получить все теги рецептов с их родственным языком рецептов?
1 ответ
Решение
После небольшого расследования я придумал следующее решение:
Добавить GenericRelation
к Recipe
модель:
from django.contrib.contenttypes.fields import GenericRelation
from django.db import models
from model_utils import Choices
from taggit_autosuggest.managers import TaggableManager
from taggit.models import TaggedItem
LANGUAGE_CHOICES = Choices(
('de', 'Allemand - Deutch'),
('en', 'Anglais - English'),
('es', 'Espagnol - Español'),
('fr', 'Français'),
('it', 'Italien - Italiano'),
('jp', 'Japonais - 日本語'),
('ko', 'Coréen - 한국어'),
('pt', 'Portugais - Português'),
('th', 'Thaï - ไทย'),
('vi', 'Vietnamien - Tiếng Việt'),
('zh', 'Chinois - 中文'),
)
class Recipe(models.Model):
language = language = models.CharField(
max_length=5,
choices=LANGUAGE_CHOICES,
default=LANGUAGE_CHOICES.en
)
tags = tags = TaggableManager(
help_text="Use tab to add a new term.",
blank=True
)
related_tags = GenericRelation(TaggedItem, related_query_name='recipes')
Затем вы можете использовать TaggedItem для создания вашего запроса:
from taggit.models import TaggedItem
from django.db.models import Count
tags = TaggedItem.objects \
.filter(content_type__app_label='recipes') \
.values_list('tag__name', 'recipes__language') \
.annotate(dcount=Count('tag_id', 'recipes__language'))