4

我想反思一个模型并列出它所有的后向通用关系。

我的模型如下所示:

class Service(models.Model):
    host = models.ForeignKey(Host)

    statuses = generic.GenericRelation(Status)

状态对象如下所示:

class Status(TrackedModel):
    content_type = models.ForeignKey(ContentType)
    object_id = models.PositiveIntegerField()
    content_object = generic.GenericForeignKey()

    class Meta:
        verbose_name_plural = 'statuses'

我想以编程方式了解这statuses是服务模型的通用关系。这可能吗?Status._meta.fields不显示statuses,但Status._meta.get_all_field_names()确实,只是它也显示了其他不需要的东西。

我认为这可能是一个可能的解决方案,但对我来说似乎真的很乱。我很想听听更好的。

from django.db.models.fields import FieldDoesNotExist
from django.contrib.contenttypes import generic

generic_relations = []
for field_name in Service._meta.get_all_field_names():
    try:
        field = Service._meta.get_field(field_name)
    except FieldDoesNotExist:
        continue

    if isinstance(field, generic.GenericRelation):
        generic_relations.append(field)

谢谢!

4

2 回答 2

3

作品GenericRelation类似。ManyToManyField您可以在以下位置找到它Service._meta.many_to_many

filter(lambda f:isinstance(f, generic.GenericRelation), Service._meta.many_to_many)
于 2012-05-22T13:47:02.343 回答
0

2021 年更新:

列出所有GenericRelations()字段:

print(Service._meta.private_fields)

输出:

[<django.contrib.contenttypes.fields.GenericRelation: statuses>]

不过,如果您有更多具有GenericRelations()关系的字段,它们将显示在输出列表中。

检查文档:

https://docs.djangoproject.com/en/3.2/releases/1.10/#id3

或者,您可以返回所有具有GenericRelation()字段类型的字段。

前任:

# models.py
class MyModel(models.Model):
    . . .
    my_model_field = GenericRelation(OtherPolyModel)


def get_generic_relation_fields(self):
   """
   This function returns all the GenericRelation 
   fields needed to return the values that are 
   related to a polymorphic model.
   """
   fields = [f.attname for f in self.Meta.model._meta.get_fields()]
   file_fields = []
   for field in fields:
       get_type = self.Meta.model._meta.get_field(field)
       field_type = get_type.__class__.__name__
            
       if field_type == "GenericRelation":
           file_fields.append(field)

       return file_fields

输出:

['my_model_field']
于 2021-11-11T22:38:27.353 回答