• python测试开发django-rest-framework-92.反序列化(ModelSerializer)之DecimalField保留2位小数


    前言

    我们在设置商品价格的时候,希望保留两位小数,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

  • 相关阅读:
    Python logging模块异步线程写日志实现过程解析
    Python数据分析实战项目介绍
    Pytorch 卷积中的 Input Shape用法
    Python 找出出现次数超过数组长度一半的元素实例
    Linux系统如何安装Python?新手教程
    MySQL 日志 复制数据库 InnoDB表空间模式 mysql默认数据库
    MySQL 8.0 窗口函数 排名、topN问题
    MySQL 求中位数 两个案例
    MySQL 创建表 复制表结构的两种方法 插入相同数据 重命名表 排查并修改字符集
    mysql if 和 case
  • 原文地址:https://www.cnblogs.com/yoyoketang/p/14348440.html
Copyright © 2020-2023  润新知