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)

上面这些例子其实灵活运用一下也可以达到最开始的效果

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

友情链接更多精彩内容