成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

如何使用Python進行正確的四舍五入?這個坑有點大

開發 后端
本文主要分享基于python的數據分析三方庫pandas,numpy的一次爬坑經歷,發現并分析了python語言對于浮點數精度處理不準確的問題,并在最后給出合理的解決方案。如果你也在用python處理數據,建議看一下。

本文主要分享基于python的數據分析三方庫pandas,numpy的一次爬坑經歷,發現并分析了python語言對于浮點數精度處理不準確的問題,并在最后給出合理的解決方案。如果你也在用python處理數據,建議看一下,畢竟0.1的誤差都可能造成比較大的影響。

問題出現

早上到了公司,領導發了幾個文件過來,說這兩天測試環境跑出來的數據,與實際情況有所出入,看看哪出的問題,盡快解決···

開始排查

  • 先對比數據,發現并不是所有的數據都出現問題,只有10%左右的數據有這個問題,說明應該不是邏輯上的問題,初步判斷可能為個別情況需要特殊處理,考慮不周導致
  • 檢查梳理各個運算模塊,用debug斷點調試一波,確定了數據出現偏差的模塊
  • 通過單獨測試這個單元模塊最終確定,涉及到兩數相除結果為0.5(浮點數)的地方有問題
  • 預期結果:np.round(0.5)=1,實際運算結果:np.round(0.5)=0,于是我做了如下的試驗
  1. # 基于python3.7版本 
  2. >>> import numpy as np 
  3.  
  4. # 先看看 0 < x < 1 這個范圍的結果,發現有問題 
  5. >>> np.round(0.50) 
  6. 0.0 
  7. >>> np.round(0.51) 
  8. 1.0 
  9. >>> np.round(0.49) 
  10. 0.0 
  11.  
  12. # 我擔心是不是只有小數點為.5的都會呈現這種問題,所以測試了 x > 1的結果,發現還是有問題 
  13. >>> np.round(1.5) 
  14. 2.0 
  15. >>> np.round(2.5) 
  16. 2.0 
  17. >>> np.round(3.5) 
  18. 4.0 
  19. >>> np.round(4.5) 
  20. 4.0 

通過對比,發現確實涉及到.5的值會有些和預想的不同,看看啥原因

分析問題

確實發現了關于浮點數(.5出現了理解上的偏差),看看官方文檔怎么解釋這個現象

  1. numpy.around(a, decimals=0, out=None)[source] 
  2. Evenly round to the given number of decimals. 
  3.  
  4. # 對于恰好介于四舍五入的十進制值之間的中間值(.5),NumPy會四舍五入為最接近的偶數值。  
  5. # 因此1.5和2.5四舍五入為2.0,-0.5和0.5四舍五入為0.0,依此類推。 
  6. For values exactly halfway between rounded decimal values,  
  7. NumPy rounds to the nearest even value.  
  8. Thus 1.5 and 2.5 round to 2.0, -0.5 and 0.5 round to 0.0, etc. 
  9.  
  10. # np.around使用快速但有時不精確的算法來舍入浮點數據類型。 
  11. # 對于正小數,它等效于np.true_divide(np.rint(a * 10 **小數),10 **小數), 
  12. # 由于IEEE浮點標準[1]和 十次方縮放時引入的錯誤 
  13. np.around uses a fast but sometimes inexact algorithm to round floating-point datatypes.  
  14. For positive decimals it is equivalent to np.true_divide(np.rint(a * 10**decimals), 10**decimals),  
  15. which has error due to the inexact representation of decimal fractions in the IEEE floating point standard [1]  
  16. and errors introduced when scaling by powers of ten 
  • 其實也就是說:對于帶有.5這種剛好介于中間的值,返回的是相鄰的偶數值
  • 白話解釋:如果一個數字帶有浮點數(.5),整數部分為偶數,則返回這個偶數;整數部分奇數,則返回這個奇數+1的偶數
  • 規律解釋:如果整數部分能夠整除2,則返回整數部分;如果整數部分不能整除2,則返回整數部分 +1

解決問題

先不做任何改動,看下數據誤差的情形

  1. # 我們為了先看下現象,構造如下案例 
  2. import pandas as pd 
  3. import numpy as np 
  4.  
  5. df = pd.DataFrame({"num1": [1, 1, 1.5, 5, 7.5], "num2": [2, 3, 1, 6, 3]}) 
  6.  
  7. df["真實值"] = df["num1"] / df["num2"
  8. # 看下round函數過后的結果 
  9. df["偏差值"] = np.round(df["num1"] / df["num2"]) 

原始結果圖片如下

 

如何使用python進行正確的四舍五入?這個坑有點大
不做處理,期望值和偏差值不等的情況出現

我的解決方案

  • 我根據我的精度要求,構建精度范圍所需要保留的小數點的最后一位,通過這個數字是否為5,判斷是否需要向上取整
  • 舉例來說,本案例中我只需要保留整數部分的數據,那么我只需要確定小數點后第一位是否是數字5就可以了

上代碼

  1. import pandas as pd 
  2. import numpy as np 
  3. import math 
  4.  
  5. df = pd.DataFrame({"除數": [1, 1, 1.5, 5, 7.5], "被除數": [2, 3, 1, 6, 3]}) 
  6.  
  7. # 記錄真實值 
  8. df["真實值"] = df["除數"] / df["被除數"
  9.  
  10. # 記錄整數部分 
  11. df["輔助整數列"] = df["真實值"].apply(lambda x: math.modf(x)[1]) 
  12.  
  13. # 記錄小數部分,因為我的最后結果精度為只保留整數部分,所以我只需要保留一個小數點位進行判斷是否需要進位操作 
  14. df["輔助小數列"] = df["真實值"].apply(lambda x: str(math.modf(x)[0]).split(".")[1][0]) 
  15.  
  16. # 小數點后的第一位是為5,則向上取整,不是5則調用原np.round就行了 
  17. df["期望值修正"] = df.apply(lambda x: x.輔助整數列 + 1 if (x.輔助小數列 == "5"else np.round(x.真實值), axis=1) 

結果如下所示

 

如何使用python進行正確的四舍五入?這個坑有點大
期望修正值已經達成

 

 

責任編輯:未麗燕 來源: 今日頭條
相關推薦

2010-06-09 11:09:06

MySQL四舍五入

2010-06-02 14:42:57

MySQL四舍五入

2021-09-29 20:56:50

MySQLMariaDB字段

2022-09-16 07:24:12

Python 的四舍

2009-11-10 17:22:23

VB.NET Form

2022-12-19 15:28:31

JavaScrip字符串

2011-04-01 16:30:26

T-SQLDateTime

2010-02-22 14:13:38

安裝Python

2010-02-03 14:15:18

Python 開發

2010-02-22 10:06:17

Python調用

2010-02-02 14:11:14

Python 進行編程

2010-02-02 18:20:43

Python編寫

2010-02-03 15:40:37

Python函數

2010-01-08 14:41:24

JSON 緩存數據

2010-01-18 17:14:50

C++語言

2024-04-10 08:39:56

BigDecimal浮點數二進制

2022-06-06 06:10:00

密碼驗證安全

2022-09-16 13:26:49

云計算云遷移數據

2023-10-18 18:38:44

數據校驗業務

2020-07-17 09:58:31

Python開發工具
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲日韩中文字幕 | 久久性色 | 国产亚洲成av人片在线观看桃 | 538在线精品| 日韩三极 | 亚洲精品456 | 成人午夜看片 | 中文字幕一区二区三区四区 | 亚洲天堂一区二区 | 91精品国产综合久久香蕉922 | 久久久久久亚洲精品 | 亚洲精品一 | 久久成人国产精品 | 日本五月婷婷 | 久久久精品网 | 欧洲免费毛片 | 免费观看色 | 操操日| 免费看黄视频网站 | 国产精品久久久久久久久免费相片 | 视频一区中文字幕 | 日韩三级电影在线看 | 在线亚洲欧美 | 日本久久久久久久久 | 国产91 在线播放 | 久久久久久久久精 | 久久精品国产一区 | 亚洲国产成人精品女人 | 精品91久久久 | 青春草在线 | 国产精品久久久久久久久免费软件 | 国产午夜一级 | 日本一区二区高清不卡 | 久久精品视频在线播放 | 欧美一区二区三区在线播放 | 日韩一区二区视频 | 99国内精品久久久久久久 | 欧洲国产精品视频 | 国产亚洲精品精品国产亚洲综合 | 国产黄色av网站 | 久久成人免费视频 |