我有一个请求模型并遵循
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/