我有一个带有两个附加SerializerMethodField
字段的序列化程序:
class BentoSerializer(ModelSerializer):
zones = SerializerMethodField()
lead_zone = SerializerMethodField()
def get_zones(self, obj):
zone_queryset = obj.get_zones()
return ZoneSerializer(zone_queryset, many=True).data
def get_lead_zone(self, obj):
zone_queryset = obj.get_lead_zone()
return ZoneSerializer(zone_queryset).data
class Meta:
model = Bento
fields = ('lead_zone', 'zones', )
我需要来自序列化程序的数据是嵌套的JSON(ZoneSerializer本身包含类似的SerializerMethodField
,除了普通的模型字段外),但是它以OrderedDict的形式出现。在
是否有一种方法可以配置序列化程序,使BentoSerializer(obj).data
返回嵌套的JSON,我是应该递归地将OrderedDicts转换为dict,还是有其他一些我不知道的用于获取非有序数据的序列化程序方法?在
非常感谢!在
PS:当前来自通过序列化程序发送的工厂对象的示例数据:
^{pr2}$
类/模型被序列化为OrderedDict类型,供
Response
方法通过此导入与Django Rest框架视图结合使用。它通常会返回内容类型中的数据,这些数据要么在编译时通过DEFAULT_RENDERER_CLASSES
项目设置分配,要么通过初始化时传递的序列化程序属性分配,要么由请求期间发送的Accept
报头确定。详细信息可在http://www.django-rest-framework.org/api-guide/renderers/的DRF文档中找到。在因此,调用
Response(BentoSerializer(obj).data)
时,当通过apieview之类的视图或ModelViewSet上的路由时,应该将JSON格式的数据返回给客户机。在但是,您也可以只
import json
并调用json.dumps(BentoSerializer(obj).data)
,然后输出所需的JSON。我用自己的序列化程序在djangoshell中测试了这一点。在相关问题 更多 >
编程相关推荐