最近在項目中碰到很多次float轉string,同時要求保留小數點后幾位,并且去掉小數點后0的場景
雖然問題很簡單,但是隔了挺久沒處理這種場景就有些生疏了,自己也搜了一下,很多回答都不太滿意。這里貼一下自己的做法,如果有更好的解決辦法的話,還請多多指教
// 主要邏輯就是先乘,trunc之后再除回去,就達到了保留N位小數的效果
func FormatFloat(num float64, decimal int) string {
// 默認乘1
d := float64(1)
if decimal > 0 {
// 10的N次方
d = math.Pow10(decimal)
}
// math.trunc作用就是返回浮點數的整數部分
// 再除回去,小數點后無效的0也就不存在了
return strconv.FormatFloat(math.Trunc(num*d)/d, 'f', -1, 64)
}
其他的一些常用的格式化浮點數的demo
// 2代表精度,這種方式會有小數點后無效的0的情況
strconv.FormatFloat(123.123 'f', 2, 64)
// 效果同上
fmt.Sprintf("%.2f", 123.123)
// g可以去掉小數點后無效的0
fmt.Sprintf("%g", 123.00)
// 效果同上,可以去掉0,但是達不到保留指定位數的效果
strconv.FormatFloat(a, 'g', -1, 64)
上面這些例子其實靈活運用一下也可以達到最開始的效果
ps:下面看下golang 浮點數保留n位小數
程序員的天敵產品同學,就像UI妹子的甲方爸爸,總會提些你不想寫的需求,還不能動手,比如某個數值經過 ÎÒ´òµÄ¾ÍÊÇÂÒÂë ,先保留3位小數,再經過%¥#@%*%¥#%,再保留2位小數,在經過䅂䌱㈳ꃥꖽ�,取整。。。。。
故,有了下面的n位取整
func ChangeNumber(f float64, m int) string {
n := strconv.FormatFloat(f, ‘f', -1, 32)
if n == “” {
return “”
}
if m >= len(n) {
return n
}。
newn := strings.Split(n, “.”)
if len(newn) 2 || m >= len(newn[1]) {
return n
}
return newn[0] + “.” + newn[1][:m]
}
為啥返回字符串類型??因為浮點數再進行各種各樣的計算之后,很可能精度丟失,其中一個方法就是進行一次運算之后轉化成字符串類型,然后由字符串類型轉化成float類型,再進行接下來的運算,穩(wěn)穩(wěn)的✧(≖ ◡ ≖✿)
總結
到此這篇關于go浮點數轉字符串保留小數點后N位的完美解決方法的文章就介紹到這了,更多相關go浮點數轉字符串內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
您可能感興趣的文章:- golang中json小談之字符串轉浮點數的操作
- 解決Golang中goroutine執(zhí)行速度的問題
- 解決golang結構體tag編譯錯誤的問題
- golang 實現Location跳轉方式
- 解決golang post文件時Content-Type出現的問題
- 對Golang中的FORM相關字段理解
- golang 打印error的堆棧信息操作
- golang 比較浮點數的大小方式