1

请原谅可能很明显是 python 新手。这是一个视图功能。它是一个 jsonp 响应,并且完全按照要求工作,非常出色(为了匿名而修改了一些元素)。

更新:这是我的功能,完成。

class stores(ListView):
    model = Store

    def get_queryset(self):

        args = [Q()]
        output = []

        callback = self.request.GET.get('callback', False)
        region = self.request.GET.get('region', False)
        country = self.request.GET.get('country', False)

        if region:
            args.append(Q(country__region_id=int(region)))

        if country:
            args.append(Q(country=int(country)))

        outputs =  self.model.objects.filter(reduce(operator.and_, args))

        for i, item in enumerate(outputs):
            outputs[i].contacts = pk__in=list(list(Contact.objects.filter(store=item.id).values()))

        return '%s(%s)' % (callback, json) if callback != False else json

这是我从脚本中得到的响应

[{"pk": 2837, "model": "store.store", "fields": {"geolocation": "-30.8040344,111.8395886", "code": "", "logo": "dist/logo/theshop_Sykes_9.jpg", "photo": "", "postcode": "2222/1111", "openinghours": "", "exclude": false, "city": "Perth", "dealer_type": "distrib", "contacts": "[{'phone': u' +1111 7000', 'fax': u'+61 2222 2122', 'type': u'general', 'email': u'notworking@theshop.com'}, {'phone': u'+61 2222 1111', 'fax': u'+61 1111 2222', 'type': u'general', 'email': u'notworking@theshop.com'}]", "servedcountries": [{"lat": "-25.244398", "lng": "132.775136", "name": "Oz"}], "comments": "", "state": "", "latitude": "-31.8040344", "legal_store": "theshop Pty Ltd", "updated": "2013-08-06T15:11:15Z", "street1": "thehouse", "street2": "Landsdale", "street3": "", "phone": "", "address": "The house", "product_type": [], "name": "theshop Pty Ltd", "sectors": "Industrial", "created": "2013-08-06T13:50:48Z", "url": "http://www.theshopsykes.com/", "country": {"lat": "-25.274398", "lng": "133.775136", "name": "Australia"}, "longitude": "115.8395886", "local_store": "theshop Pty Ltd"}}]

将该字符串粘贴到 json 解码器中,例如http://json.parser.online.fr/中的那个

您会看到没有正确解析联系人元素。

我努力了:

outputs[i].contacts = serializers.serialize("json", Contact.objects.filter(distributor=item.id), use_natural_keys=True)

但我得到一个错误。

AttributeError: 'unicode' object has no attribute 'name'

这是模型声明,以防万一。

class Contact(models.Model):
    contact_type = models.CharField('Email Type', max_length='20', choices=(('sales', 'Sales'), ('support', 'Support'), ('general', 'General')), blank=True)
    email = models.EmailField(max_length=200, blank=True)
    phone = models.CharField('Phone Number', max_length=200, blank=True)
    fax = models.CharField('Fax Number', max_length=200, blank=True)
    store = models.ForeignKey(Store)

    def __unicode__(self):
        return self.contact_type

    def natural_key(self):
        return self.contact_type
4

2 回答 2

0

我猜您正在寻找序列化相关对象(联系人,与商店相关)。

由于这是一个不平凡的问题,我建议看一下https://code.google.com/p/wadofstuff/wiki/DjangoFullSerializers之类的东西——不确定 Django 核心中是否还有更新的选项(选择相关?)。

干杯,

于 2013-09-25T15:26:37.493 回答
0

史蒂夫,我认为你对序列化如何工作的想法是有缺陷的。我设想一个从查询集到 JSON 响应的过程是一个两步过程,而 Django 序列化程序同时完成了这两个过程。

1)将查询集变成字符串和数字的字典。2) 将该字典转换为 JSON。

第 1 步比人们想象的要难。例如,序列化程序必须决定哪些属性被序列化。例如,如果您要在模型上定义一个属性,它们似乎正在被序列化(否则联系人不会出现)。我期待 Django 序列化程序只序列化模型字段,但我猜不是!

它还必须决定如何将关系呈现给其他模型。这称为嵌套,有多种选择:仅列出相关模型的主键,或包含它的序列化版本。可以只列出相关模型的主键,或者包括一个或多个深度级别。

--

就解决您的问题而言,我可以提出两点建议:

  • 正如 madflo 建议的那样,Django 序列化程序可能对您的需求来说太基础了。我会看看还有什么可用的。就个人而言,我是 Django Rest Framework 的忠实粉丝。但这对您的用例来说可能有点过分了。他们关于嵌套的文档可能仍然有用。
  • servedcountries我会好好看看和之间的区别contacts。似乎servedcountries是一个相关模型正在按预期进行序列化,所以找出为什么会这样,contacts而不是这样。包含 Store 模型的声明会很有帮助。

评论:

我不太确定这条线;我想你的意思是pk__in_list

outputs[i].contacts = pk__in=list(list(Contact.objects.filter(store=item.id).values()))

无论如何,如果我理解正确,您应该可以将其替换为

outputs[i].contacts = Contacts.objects.filter(store=item.id).values_list('pk', flat=True)
于 2013-09-27T11:14:46.150 回答