python 双精度浮点数_python怎么输出浮点数?

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)

原文至:https://www.py.cn/jishu/jichu/13388.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值