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
- 1 回答
- 0 關注
- 128 瀏覽
添加回答
舉報