go浮点数转字符串保留⼩数点后N位的完美解决⽅法
最近在项⽬中碰到很多次float转string,同时要求保留⼩数点后⼏位,并且去掉⼩数点后0的场景
虽然问题很简单,但是隔了挺久没处理这种场景就有些⽣疏了,⾃⼰也搜了⼀下,很多回答都不太满意。这⾥贴⼀下⾃⼰的做法,如果有更好的解决办法的话,还请多多指教
// 主要逻辑就是先乘,trunc之后再除回去,就达到了保留N位⼩数的效果
字符串截取前2位func FormatFloat(num float64, decimal int) string {
// 默认乘1
d := float64(1)
if decimal > 0 {
// 10的N次⽅
d = math.Pow10(decimal)
}
// unc作⽤就是返回浮点数的整数部分
// 再除回去,⼩数点后⽆效的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浮点数转字符串内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。