1. 程式人生 > 程式設計 >go浮點數轉字串保留小數點後N位的完美解決方法

go浮點數轉字串保留小數點後N位的完美解決方法

最近在專案中碰到很多次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',64)

上面這些例子其實靈活運用一下也可以達到最開始的效果

ps:下面看下golang 浮點數保留n位小數

程式設計師的天敵產品同學,就像UI妹子的甲方爸爸,總會提些你不想寫的需求,還不能動手,比如某個數值經過 ÎÒ´òµÄ¾ÍÊÇÂÒÂë ,先保留3位小數,再經過%¥#@%&*%¥#%,再保留2位小數,在經過䅂䌱㈳ꃥꖽ�,取整。。。。。

故,有了下面的n位取整

func ChangeNumber(f float64,m int) string {
n := strconv.FormatFloat(f,‘f',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型別,再進行接下來的運算,穩穩的✧(≖ ◡ ≖✿)

總結

到此這篇關於go浮點數轉字串保留小數點後N位的完美解決方法的文章就介紹到這了,更多相關go浮點數轉字串內容請搜尋我們以前的文章或繼續瀏覽下面的相關文章希望大家以後多多支援我們!