我有以下代码:
数据/电话.py:
class TelephoneNumber(models.Model):
MOBILE = 0
HOME = 1
TELEFON_CHOICES = (
(MOBILE, _("Mobile")),
(HOME, _("Landline")),
)
object_id = models.PositiveIntegerField()
content_type = models.ForeignKey(ContentType)
of = generic.GenericForeignKey('content_type', 'object_id' )
label = models.SmallIntegerField(choices=TELEFON_CHOICES)
number = models.CharField(max_length=20, blank=True)
模型.py:
class Staff(models.Model):
user = models.OneToOneField(User)
telephonenumbers = GenericRelation(TelephoneNumber, related_query_name='telnumber')
不,我想提供一个功能来检索用户的每个电话号码,如下所示:
def get_telnumbers(self):
tellist = []
#print(self.telephonenumbers.all())
for tel in self.telephonenumbers.all():
tellist.append(tel)
return tellist
问题是,该线路print(self.telephonenumbers.all())
不打印任何电话号码,即使已经提供了很多。返回的字典也是空的。
如何访问保存在Staff
上下文中的 GenericRelation 对象?
编辑:
以下代码:
for tel in TelephoneNumber.objects.all():
print(tel)
print(tel.of)
给我保存的每个电话号码,并通过tel.of
电话号码所属的正确员工用户。
那么为什么不self.telephonenumbers.all()
工作(self.user
也返回应该保存电话号码的正确用户)?