Django:返回外键的自定义字段值替换filter()中的id号

时间:2013-08-08 09:18:43

标签: django filter foreign-keys

我有下面的models.py

class site(models.Model):
    site_name = models.CharField(max_length=10)
    site_description = models.CharField(max_length=30, blank=True, null=True)
    def __unicode__(self):
        return self.site_name

class asset(models.Model):
    STAT_CHOICES = (('Available', 'Available'), ('Deployed', 'Deployed'), ('Down', 'Down'))
    asset_id = models.CharField(max_length=30, primary_key=True)
    owner = models.CharField(max_length=30, blank=True, null=True)
    status = models.CharField(choices=STAT_CHOICES, max_length=30, blank=True, null=True)
    site = models.ForeignKey(it_asset_site)
    notes = models.CharField(max_length=300, blank=True, null=True)

    def __unicode__(self):
        return self.asset_id

众所周知,默认情况下,表“site”会将site_id创建为PK。 在我将数据导入表“asset”后,在django的admin中,“site”显示为“site_name”。这种效果来自“def unicode (self):”。 所以我希望得到同样的效果

f = asset.objects.filter(site__site_name__contains='NNG1')

但是在“f”中,“site”字段显示的数字(site_id)不是NNG1(site_name),样本:

b = f.filter(site__site_name__contains='NNG1')
In [44]: b.values()[0]
Out[44]: 
{'asset_id': u'3914100271',
 'owner': u'',
 'status': None,
 'site_id': 8L,*****<-now*****
 'notes': u'',
}

有一种方法可以使过滤结果变为:

{'asset_id': u'3914100271',
 'owner': u'',
 'status': None,
 'site_name': u'NNG1',*****<-hope*****
 'notes': u'',
}
像pjango管理页面显示? 感谢

1 个答案:

答案 0 :(得分:0)

您可以在values()中指定字段作为参数:

b.values('asset_id', 'owner', 'status', 'site__name', 'notes')[0]