亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

是否有任何標準庫可以將 float64 轉換為具有最大有效位數的固定寬度的字符串?

是否有任何標準庫可以將 float64 轉換為具有最大有效位數的固定寬度的字符串?

Go
慕妹3146593 2022-01-04 10:22:11
想象一下,要在 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 位有效數字。是否有任何標準庫可以轉換float64為string具有最大有效位數的固定寬度?提前致謝。
查看完整描述

1 回答

?
互換的青春

TA貢獻1797條經驗 獲得超6個贊

基本上,您有 2 種輸出格式:科學記數法或常規格式。這兩種格式之間的轉折點是1e12.


所以你可以分支 if x >= 1e12。在兩個分支中,您都可以使用 0 小數位進行格式化以查看數字的長度,因此您可以計算出適合 12 寬度的小數位數,因此您可以使用計算出的精度構造最終的格式字符串.


科學記數法(%g)中也需要預先檢查,因為指數的寬度可能會有所不同(例如e+1,e+10,e+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


查看完整回答
反對 回復 2022-01-04
  • 1 回答
  • 0 關注
  • 128 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號