package mainimport "fmt"import "os"type point struct { x, y int}func main() {//Go 為常規 Go 值的格式化設計提供了多種列印方式。例如,這裡列印了 point 結構體的一個執行個體。 p := point{1, 2} fmt.Printf("%v\n", p) // {1 2}//如果值是一個結構體,%+v 的格式化輸出內容將包括結構體的欄位名。 fmt.Printf("%+v\n", p) // {x:1 y:2}//%#v 形式則輸出這個值的 Go 文法表示。例如,值的運行原始碼片段。 fmt.Printf("%#v\n", p) // main.point{x:1, y:2}//需要列印值的類型,使用 %T。 fmt.Printf("%T\n", p) // main.point//格式化布爾值是簡單的。 fmt.Printf("%t\n", true)//格式化整形數有多種方式,使用 %d進行標準的十進位格式化。 fmt.Printf("%d\n", 123)//這個輸出二進位表示形式。 fmt.Printf("%b\n", 14)這個輸出給定整數的對應字元。 fmt.Printf("%c\n", 33)%x 提供十六進位編碼。 fmt.Printf("%x\n", 456)//對於浮點型同樣有很多的格式化選項。使用 %f 進行最基本的十進位格式化。 fmt.Printf("%f\n", 78.9)//%e 和 %E 將浮點型格式化為(稍微有一點不同的)科學技科學記號標記法表示形式。 fmt.Printf("%e\n", 123400000.0) fmt.Printf("%E\n", 123400000.0)//使用 %s 進行基本的字串輸出。 fmt.Printf("%s\n", "\"string\"")//像 Go 原始碼中那樣帶有雙引號的輸出,使用 %q。 fmt.Printf("%q\n", "\"string\"")//和上面的整形數一樣,%x 輸出使用 base-16 編碼的字串,每個位元組使用 2 個字元表示。 fmt.Printf("%x\n", "hex this")//要輸出一個指標的值,使用 %p。 fmt.Printf("%p\n", &p)//當輸出數位時候,你將經常想要控制輸出結果的寬度和精度,可以使用在 % 後面使用數字來控制輸出寬度。預設結果使用靠右對齊並且通過空格來填充空白部分。 fmt.Printf("|%6d|%6d|\n", 12, 345)//你也可以指定浮點型的輸出寬度,同時也可以通過 寬度.精度 的文法來指定輸出的精度。 fmt.Printf("|%6.2f|%6.2f|\n", 1.2, 3.45)//要最對齊,使用 - 標誌。 fmt.Printf("|%-6.2f|%-6.2f|\n", 1.2, 3.45)//你也許也想控制字元串輸出時的寬度,特別是要確保他們在類表格輸出時的對齊。這是基本的靠右對齊寬度表示。 fmt.Printf("|%6s|%6s|\n", "foo", "b")//要靠左對齊,和數字一樣,使用 - 標誌。 fmt.Printf("|%-6s|%-6s|\n", "foo", "b")//到目前為止,我們已經看過 Printf了,它通過 os.Stdout輸出格式化的字串。Sprintf 則格式化並返回一個字串而不帶任何輸出。 s := fmt.Sprintf("a %s", "string") fmt.Println(s)//你可以使用 Fprintf 來格式化並輸出到 io.Writers而不是 os.Stdout。 fmt.Fprintf(os.Stderr, "an %s\n", "error")}