如圖,Python2.7在使用eval計(jì)算浮點(diǎn)數(shù)表達(dá)式的時(shí)候,
eval('0.3-0.1==0.2') # 輸出為False
eval('%d - %d == %d'%(0.3, 0.1, 0.2)) # 輸出為True
eval('%s - %s == %s'%(0.3, 0.1, 0.2)) # 輸出為False
eval('%s - %s == %s'%('0.3', '0.1', '0.2')) # 輸出為False
這就讓人特別疑惑了,在網(wǎng)上沒找到答案,請(qǐng)高手指導(dǎo)!
更新:
還有個(gè)問題請(qǐng)教下,
a=0.3-0.1,print(a)輸出0.19999999999999998;b=0.2,
但是print('%s==%s'%(a,b))卻輸出的是 0.2==0.2,
這里為什么在格式化字符串的時(shí)候,a由0.19999999999999998變成了0.2呢?
一般在計(jì)算機(jī)里不能直接用 ==
比較2個(gè)浮點(diǎn)數(shù)是否相等。
因?yàn)楦↑c(diǎn)數(shù)值在計(jì)算機(jī)存在誤差。
python有 decimal
和 fraction
2個(gè)模塊用來進(jìn)行高精度浮點(diǎn)計(jì)算。
例子
>>> from fractions import Fraction
>>> Fraction('0.3')-Fraction('0.1') == Fraction('0.2')
True
>>> from decimal import Decimal
>>> Decimal('0.3')-Decimal('0.1') == Decimal('0.2')
True
>>>
這和eval沒什么關(guān)系,主要是精度問題,這個(gè)在所有的編程語言都會(huì)遇到,你試試 0.3-0.1 == 0.2 都會(huì)直接返回False. 百度 JavaScript 0.2-0.1問題,然后看一下《計(jì)算機(jī)組成原理》最開始的 數(shù)據(jù)表示。
https://stackoverflow.com/que... 這個(gè)是 一個(gè)高票回答。