扫二维码与项目经理沟通
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流
python 里面专门有一个 round() 函数可以将任意的浮点数或者小数保留指定的位数。
成都创新互联作为成都网站建设公司,专注网站建设公司、网站设计,有关成都企业网站建设方案、改版、费用等问题,行业涉及成都服务器租用等多个领域,已为上千家企业服务,得到了客户的尊重与认可。
废话不多说了,直接上一个例子。
目标:将 x = 34.4567809278 保留3位小数
结果 34.457
round(x,k) 中 x 为要处理的浮点数, k 指要保留的位数
print(round(x)) #直接返回整数
python提供了三种浮点值:内置的float与complex类型,以及标准库的decimal.Decimal类型。
float类型存放双精度的浮点数,具体取值范围依赖于构建python的c编译器,由于精度受限,进行相等性比较不可靠。
如果需要高精度,可使用decimal模块的decimal.Decimal数,这种类型可以准确的表示循环小数,但是处理速度较慢,适合于财政计算。
相关推荐:《Python基础教程》
简单函数比较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)
方法很多。
比如,可以用isinstance函数或type函数。
例子如下:
print(isinstance(1.,float))
print(type(1.)==float)
答: 假设用变量m接收具体的输入值,可使用float函数将输入的内容转化为浮点数,具体代码如下。
m = float(input("请输入一个数:"))
具体的功能即把输入的一个数转化为浮点数。
具体的实例如下所示。
对应打印结果如下。
希望可以帮助到你~
我们在微信上24小时期待你的声音
解答本文疑问/技术咨询/运营咨询/技术建议/互联网交流