前言
我们在设置商品价格的时候,希望保留两位小数,FloatField是浮点数无法精确小数点几位,DecimalField可以精确几位小数点
DecimalField
models.py设置商品表模型的时候,可以把商品价格设置DecimalField
- max_digits=10 整数位的长度为10位
- decimal_places=2 小数点后2位
- blank=True 允许为空格
- null=True 允许为空
- default=0 默认值为0
- verbose_name="商品价格" 设置字段名称
class Goods(models.Model):
"""商品表"""
goods_price = models.DecimalField(max_digits=10, decimal_places=2,
blank=True, null=True,
default=0, verbose_name="商品价格")
提交数据的时候,goods_price 值为12.1 但是查询出来是保留2位小数点 12.10
写到数据库的数据是12.1
序列化DecimalField
关于DecimalField(max_digits, decimal_places, coerce_to_string=None, max_value=None, min_value=None)相关参数
- max_digits 数字中允许的最大位数。它必须是 None 或大于等于 decimal_places 的整数。
- decimal_places 以数字存储的小数位数。
- max_value 验证所提供的数字不大于这个值。
- min_value 验证所提供的数字不小于这个值。
- localize 设置为 True 以便基于当前区域启用输入和输出本地化。这也将强制 coerce_to_string 为 True。默认为 False。请注意,如果在设置文件中设置了 USE_L10N = True,则会启用数据格式化。
- coerce_to_string 如果用于表示应返回字符串值,则设置为 True;如果应返回 Decimal 对象,则设置为 False。默认与 COERCE_DECIMAL_TO_STRING 设置中的键值相同,除非重写,否则将为 True。如果序列化器返回 Decimal 对象,则最终输出格式将由渲染器确定。请注意,设置 localize 会将值强制为 True。
- rounding 设置量化到配置精度时使用的舍入模式。有效值是 decimal 模块舍入模式。默认为 None。
序列化goods_price 字段
# 作者-上海悠悠 QQ交流群:717225969
# blog地址 https://www.cnblogs.com/yoyoketang/
class GoodsSerializer(serializers.ModelSerializer):
"""序列化商品models"""
create_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
update_time = serializers.DateTimeField(format='%Y-%m-%d %H:%M:%S', required=False)
goods_price = serializers.DecimalField(max_digits=10,
decimal_places=2,
max_value=10000.00,
min_value=0.00
)
class Meta:
model = Goods
fields = '__all__' # 返回全部的字段
此时提交成功后,goods_price变成了字符串类型
coerce_to_string 如果用于表示应返回字符串值,则设置为 True;如果应返回 Decimal 对象,则设置为 False。
goods_price = serializers.DecimalField(max_digits=10,
decimal_places=2,
max_value=10000.00,
min_value=0.00,
coerce_to_string=False
)
这时候返回的是浮点数12.0