Как отфильтровать теги 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'))
Другие вопросы по тегам