package main import "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") }