华域联盟 Golang 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', -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类型,再进行接下来的运算,稳稳的(≖ ◡ ≖)

总结

到此这篇关于go浮点数转字符串保留小数点后N位的完美解决方法的文章就介绍到这了,更多相关go浮点数转字符串内容请搜索华域联盟以前的文章或继续浏览下面的相关文章希望大家以后多多支持华域联盟!

本文由 华域联盟 原创撰写:华域联盟 » go浮点数转字符串保留小数点后N位的完美解决方法

转载请保留出处和原文链接:https://www.cnhackhy.com/110724.htm

本文来自网络,不代表华域联盟立场,转载请注明出处。

作者: sterben

成功安装vscode中go的相关插件(详细教程)

Go语言框架Beego项目搭建的方法步骤

发表回复

联系我们

联系我们

2551209778

在线咨询: QQ交谈

邮箱: [email protected]

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们