开发者社区> 问答> 正文

如何在python中打小数点

问题来源于python学习网

展开
收起
保持可爱mmm 2019-12-10 15:44:55 337 0
1 条回答
写回答
取消 提交回答
  • python提供了三种浮点值:内置的float与complex类型,以及标准库的decimal.Decimal类型。

    float类型存放双精度的浮点数,具体取值范围依赖于构建python的c编译器,由于精度受限,进行相等性比较不可靠。

    如果需要高精度,可使用decimal模块的decimal.Decimal数,这种类型可以准确的表示循环小数,但是处理速度较慢,适合于财政计算。

    简单函数比较floatS是否相等:

    def equal_float(a,b):

    return abs(a-b)<=sys.float_info.epsilon

    其中sys.float_info.epsilon是机器可以区分出的两个浮点数的最小区别

    math模块提供了许多可用于floatS的函数:

    math.pi:常量3.1415926

    math.pow(x,y):x的y次幂(浮点值)

    使用math时先用import math导入该模块

    十进制数字

    decimal模块可以提供固定的十进制数,精度可以自己定。要创建Decimal,要先用import decimal导入模块

    十进制数是用decimal.Decimal()函数创建的,该函数可以接受一个整数或字符串作为参数,但不能以浮点数作参数。如果用字符串作为参数,可以使用简单的十进制数表示或指数表示,另外,decimal.Decimal的精确表述方式可以可靠的进行相等性比较

    (python3.1开始,使用decimal.Decimal from-float()函数将floats转换为十进制数,以float型数作为参数,并返回与该float最为接近的decimal.Decimal)

    2019-12-10 15:45:09
    赞同 展开评论 打赏
问答分类:
问答标签:
问答地址:
问答排行榜
最热
最新

相关电子书

更多
From Python Scikit-Learn to Sc 立即下载
Data Pre-Processing in Python: 立即下载
双剑合璧-Python和大数据计算平台的结合 立即下载