在列表序列化程序 class 中覆盖 to_representation
Override to_representation in List serializer class
我有一个实现 BaseSerializer
class 的序列化器,我在其中使用 to_representation
函数来执行如下函数调用:
class ItemSerializer(serializers.BaseSerializer):
def to_representation(self, instance):
ret = super().to_representation(instance)
ret['log'] = SERVICE.log(instance.id)
return ret
class Meta:
list_serializer_class = ItemListSerializer
model = models.Item
fields = '__all__'
我也有一个相同的 ItemListSerializer
的列表序列化程序,如下所示:
class ItemListSerializer(serializers.ListSerializer):
def create(self, validated_data):
items = [models.Item(**item) for item in validated_data]
return models.Item.objects.bulk_create(items)
我想做的是覆盖 ItemSerializer
中的 to_representation
方法,以便在我想要获取整个项目列表时使用。我基本上想避免对每个项目进行函数调用,而是在出于性能原因请求项目列表时对所有项目进行批量调用。
有什么好的方法吗?我按照这些文档创建 ItemListSerializer
:https://www.django-rest-framework.org/api-guide/serializers/#customizing-listserializer-behavior 但它只讨论覆盖创建和更新方法。
您可以访问 ListSerializer.to_representation
中的所有项目
这应该是一个随心所欲的好地方。
该方法如下所示:
def to_representation(self, data):
"""
List of object instances -> List of dicts of primitive datatypes.
"""
# Dealing with nested relationships, data can be a Manager,
# so, first get a queryset from the Manager if needed
iterable = data.all() if isinstance(data, models.Manager) else data
return [
self.child.to_representation(item) for item in iterable
]
但老实说,我看不出你能从中得到什么。您的用例看起来不会带来可衡量的性能提升。
我有一个实现 BaseSerializer
class 的序列化器,我在其中使用 to_representation
函数来执行如下函数调用:
class ItemSerializer(serializers.BaseSerializer):
def to_representation(self, instance):
ret = super().to_representation(instance)
ret['log'] = SERVICE.log(instance.id)
return ret
class Meta:
list_serializer_class = ItemListSerializer
model = models.Item
fields = '__all__'
我也有一个相同的 ItemListSerializer
的列表序列化程序,如下所示:
class ItemListSerializer(serializers.ListSerializer):
def create(self, validated_data):
items = [models.Item(**item) for item in validated_data]
return models.Item.objects.bulk_create(items)
我想做的是覆盖 ItemSerializer
中的 to_representation
方法,以便在我想要获取整个项目列表时使用。我基本上想避免对每个项目进行函数调用,而是在出于性能原因请求项目列表时对所有项目进行批量调用。
有什么好的方法吗?我按照这些文档创建 ItemListSerializer
:https://www.django-rest-framework.org/api-guide/serializers/#customizing-listserializer-behavior 但它只讨论覆盖创建和更新方法。
您可以访问 ListSerializer.to_representation
这应该是一个随心所欲的好地方。
该方法如下所示:
def to_representation(self, data):
"""
List of object instances -> List of dicts of primitive datatypes.
"""
# Dealing with nested relationships, data can be a Manager,
# so, first get a queryset from the Manager if needed
iterable = data.all() if isinstance(data, models.Manager) else data
return [
self.child.to_representation(item) for item in iterable
]
但老实说,我看不出你能从中得到什么。您的用例看起来不会带来可衡量的性能提升。