例如,DRF的输出如下:
[{"created_on": "2016-04-23"},{"created_on": "2016-05-23"}]
我想要的是:
[{"Created on": "2016-04-23"},{"Created on": "2016-05-23"}]
如果没有我重写序列化过程,这可能吗?
解决方法 不,它不可能(当前)没有覆盖序列化过程.为什么不可能?
这是因为您要用于created_on的备用名称包含空格,并且无法在序列化程序中定义具有空格的字段.此外,目前没有功能为序列化过程中使用的字段提供备用名称.
可能解决方案
您可以覆盖序列化程序的to_representation()方法,并添加一个Created On键,其值等于created_on键的值.然后,所有序列化对象都将包含一个创建的密钥.
class MySerializer(serializers.ModelSerializer): ... def to_representation(self,obj): primitive_repr = super(MySerializer,self).to_representation(obj) primitive_repr['Created On'] = primitive_repr['created_on'] return primitive_repr
如果备用名称不包含任何空格怎么办?
如果备用名称之间没有任何空格,则可以使用带有source参数的SerializerMethodFIEld().
你可以这样做:
class MySerializer(serializers.ModelSerializer): alternate_name = serializers.SerializerMethodFIEld(source='created_on') class Meta: model = MyModel fIElds = (..,'alternate_name')总结
以上是内存溢出为你收集整理的使用Django休息框架时更改字段名称全部内容,希望文章能够帮你解决使用Django休息框架时更改字段名称所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)