标签:python Decimal len a1 m1 m2 print 数据 精度
一、python运算时精度问题:
1.运行时精度问题
在Python中(其他语言中也存在这个问题,这是计算机采用二进制导致的),有时候由于二进制和十进制之间对应问题会导致数值的精度问题,比如无法用有限个二进制位完整地表示0.1,因为0.1转化为二进制之后位一个无限循环小数
print(1.1*2.2)
查看运行结果:
2.解决方案:添加方法
需要将整数部分与小数部分单独做处理可以解决
def multiple(m1, m2): r='' ## 若存在浮点型,则先转化为整数 if type( m1 )==float or type( m2 )==float: print( "存在浮点数" ) len_m1=len( str( m1 ).split( "." )[1] ) len_m2=len( str( m2 ).split( "." )[1] ) print( "m1的小数位:", len_m1 ) print( "m2的小数位:", len_m2 ) m1=int( 10**len_m1*m1 ) m2=int( 10**len_m2*m2 ) print( "m1化为整数:", m1 ) print( "m2化为整数:", m2 ) r=str( m1*m2 ) print( "r:", r ) l=len_m1+len_m2 print( "l的总长度:", l ) if l<len( r ): r_front=r[:-l] r_last=r[-l:] print( r_front, "-", r_last ) r=r_front+"."+r_last else: r="0."+(l-len( r ))*"0"+r else: print( "不存在浮点数" ) r=m1*m2 return r res = multiple(1.1,2.2) print(res)
查看运行结果:
二、python四舍五入时精度问题:
1.使用round与浮点数格式化时候的精度问题
归根结底是计算机存储浮点数的问题
a1 = 0.235 a2 = round(a1,2) a3 = '%.2f' % a1 print(a2) print(a3)
查看运行结果:
2.解决方案,使用Decimal函数
需要将float转换为Decimal,该类可以通过接受字符串(务必是字符串)形式的浮点数实现相对精确的小数计算(减缓了精度误差,但没有消灭)
from decimal import Decimal a1 = 0.235 a2 = Decimal(str(a1)).quantize(Decimal("0.00")) a3 = '{:.2f}'.format(Decimal(str(a1))) print(a2) print(a3)
查看运行结果:
标签:python,Decimal,len,a1,m1,m2,print,数据,精度 来源: https://www.cnblogs.com/mrwhite2020/p/16637914.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。