gpt4 book ai didi

python - 从具有不同名称的数据值设置序列化器字段(ModelSerizer 的自定义字段映射)

转载 作者:行者123 更新时间:2023-12-01 09:25:52 26 4
gpt4 key购买 nike

我有一个请求模型并遵循

class TruRouteRequest(models.Model):
msisdn = models.CharField('Subscriber international MSISDN ', max_length=25)
sessionid = models.CharField(max_length=100, unique=True)
msg_type = models.CharField(max_length=255)
msg = models.CharField(max_length=255)

我未能将模型字段的名称写为“type”,因此我写了“msg_type”。我有一个用于上述模型的 ModelSerializer。我收到的数据具有必需的字段“类型”。如何将 type 从序列化器数据映射到 msg_type 以避免调用有效时出现此错误

>> serializer = TruRouteRequestSerializer(data=request.data)
>> serializer.data
>> {'msisdn': 'M', 'sessionid': 'S', 'msg': 'MSG'}
>> request.data
>> {'msisdn': 'M', 'type': 'T', 'sessionid': 'S', 'msg': 'MSG'} # there is type
>> serializer.is_valid()
>> False
>> serializer.errors
>> {'msg_type': [ErrorDetail(string='This field is required.', code='required')]}

最佳答案

您可以在序列化程序中显式定义 type 字段,并使用 source 参数将其映射到 msg_type 字段:

class TruRouteRequestSerializer(serializers.ModelSerializer):
type = serializers.CharField(source='msg_type')

class Meta:
model = TruRouteRequest
fields = ['type', ...]

关于python - 从具有不同名称的数据值设置序列化器字段(ModelSerizer 的自定义字段映射),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50402446/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com