1. 程式人生 > >python-正確保留多位小數

python-正確保留多位小數

  • python自帶的float函式在保留兩位小數的時候不夠準確容易出現誤差,而(‘%.2f’ % a)的方式是將數字轉成了字串型別,無法進行數字運算,所以這裡我們將封裝一個方法來實現正確的保留多位小數。

    1234567891011121314 from functools import reducedef str2float(strf): def char2num(s): return {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}[s] def char2int
    (x, y):
    return 10 * x + y tstr = strf.split('.') hightre = reduce(char2int, map(char2num, tstr[0])) if len(tstr)>1: lowre = reduce(char2int, map(char2num, tstr[1]))*(0.1**len(tstr[1])) else: lowre = 0 return hightre + lowre
  • 從上述程式碼我們引用了reduce函式(python2.7不需要匯入)配合map內建函式來實現;

  • char2num函式主要是將字串類似轉為對應的數字型別;
  • char2int函式實現左側的數字乘以10後加上右側數字,比如char2int(1,2)-> 12;
  • tstr是將高位數和低位數通過”.”隔開;
  • hightre是處理高位數,即非小數位部分,tstr[0]將左側的數字通過char2num函式轉成數字型別,作為單個單個的數字,如(”123.456”)將小數點左側的部分轉為(1,2,3),通過char2int函式轉為(((110+2)10)+3) -> 123;
  • lowre是處理低位數,即小數位部分,tstr[1]將右側的數字通過char2num函式轉成數字型別,作為單個單個的數字,如(”123.456”)將小數點右側的部分轉為(4,5,6),通過char2int函式轉為(((410+5)
    10)+6) -> 456,由於是小數位所以要乘以0.1的N次方(N=小數位的位數),(456(0.10.1*0.1)) -> 0.456;
  • 最後返回高位數拼接低位數,即123.456的浮點型別;

  • PS:經過試驗發現,使用該方法最多可支援12位數字,即高位數和低位數總位數在12位以內可以正常顯示;