登录
首页 >  Golang >  Go问答

是否有任何标准库可以将 float64 转换为具有最大有效位数的固定宽度的字符串?

来源:Golang技术栈

时间:2023-04-17 18:58:08 408浏览 收藏

本篇文章主要是结合我之前面试的各种经历和实战开发中遇到的问题解决经验整理的,希望这篇《是否有任何标准库可以将 float64 转换为具有最大有效位数的固定宽度的字符串?》对你有很大帮助!欢迎收藏,分享给更多的需要的朋友学习~

问题内容

想象一下,在 12 个固定宽度的表格中打印我们需要打印float64数字:

fmt.Printf("%12.6g\n", 9.405090880450127e+119) //"9.40509e+119"
fmt.Printf("%12.6g\n", 0.1234567890123)        //"    0.123457"
fmt.Printf("%12.6g\n", 123456789012.0)         //" 1.23457e+11"

我们更喜欢 0.1234567890 而不是“0.123457”,我们会丢失 6 个有效数字。
我们更喜欢 123456789012 而不是“1.23457e+11”,我们会丢失 6 个有效数字。

是否有任何标准库可以转换float64string具有最大有效位数的固定宽度?提前致谢。

正确答案

基本上,您有 2 种输出格式:科学记数法或常规形式。这两种格式之间的转折点是1e12.

所以你可以分支 if x >= 1e12。在这两个分支中,您可以使用 0 小数位进行格式化以查看数字的长度,因此您可以计算 12 宽度适合多少小数位,因此您可以使用计算出的精度构造最终格式字符串.

科学记数法中也需要预先检查(%g),因为指数的宽度可能会有所不同(例如e+1e+10e+100)。

这是一个示例实现。这是为了让您入门,但这并不意味着处理所有情况,并且它不是最有效的解决方案(但相对简单并且可以完成工作):

// format12 formats x to be 12 chars long.
func format12(x float64) string {
    if x >= 1e12 {
        // Check to see how many fraction digits fit in:
        s := fmt.Sprintf("%.g", x)
        format := fmt.Sprintf("%%12.%dg", 12-len(s))
        return fmt.Sprintf(format, x)
    }

    // Check to see how many fraction digits fit in:
    s := fmt.Sprintf("%.0f", x)
    if len(s) == 12 {
        return s
    }
    format := fmt.Sprintf("%%%d.%df", len(s), 12-len(s)-1)
    return fmt.Sprintf(format, x)
}

测试它:

fs := []float64{0, 1234.567890123, 0.1234567890123, 123456789012.0, 1234567890123.0,
    9.405090880450127e+9, 9.405090880450127e+19, 9.405090880450127e+119}

for _, f := range fs {
    fmt.Println(format12(f))
}

输出(在Go Playground上试试):

0.0000000000
0.1234567890
1234.5678901
123456789012
1.234568e+12
9405090880.5
9.405091e+19
9.40509e+119

以上就是《是否有任何标准库可以将 float64 转换为具有最大有效位数的固定宽度的字符串?》的详细内容,更多关于golang的资料请关注golang学习网公众号!

声明:本文转载于:Golang技术栈 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表