1

所以问题是我有一个有外键的类。

这是我的代码

class Proxy(models.Model):
  class Meta:
    db_table = 'Proxy'
  equipment = models.ForeignKey('Equipment', primary_key=True)      
  pop = models.ForeignKey('Pop')

现在,像往常一样,当我这样做时

import django.core.serializers as Serializer
res = Proxy.objects.filter(equipment_id__exact='eq1')
Serializer.serialize('json', res)

json 输出包含 Pop 的“id”而不是我想要的名称。

所以我使用了 Manager 类,这是我现在的 Pop 类-

class PopManager(models.Manager):
  def get_by_natural_key(self, name):
    return self.get(name=name)

class Pop(models.Model):
  POP_TYPES = (
    ('phy','phy'),
    ('cloud','cloud'),
  )

  class Meta:
    db_table = 'Pop'
    unique_together = ('name', 'vip')
  objects = PopManager()
  name = models.CharField(max_length=10)
  type = models.CharField(max_length=10, choices=POP_TYPES)

  def natural_key(self):
    return (self.name)

但在此之后,当我这样做时

res = Proxy.objects.filter(equipment_id__exact='eq1')
Serializer.serialize('json', res, use_natural_keys=True)

我收到一个错误,TypeError: Equipment: eq1 is not JSON serializable

我也尝试过 wadofstuff 用于外键的序列化,但显然在 Django1.5 中,simplejson 和 json 之间存在冲突,并且查询抛出错误。所以我回到第一方。

任何帮助将不胜感激。我已经把头发分开了好几个小时。

4

2 回答 2

0

无论如何,所以我通过将 QuerySet 转换为原始字典类型格式来解决这个问题。我在过滤器之后附加了一个值子句。并遍历返回的整个查询集以制作字典列表。其余的很容易。

于 2013-03-31T19:22:16.967 回答
0

阿尼瓦,

你只需要删除你的行:

db_table = '流行音乐'

于 2013-11-13T17:35:25.957 回答