golang 的 fmt
包實現了格式化I/O函式,類似於C的 printf
和 scanf
。
# 定義示例型別和變數
type Human struct {
Name string
}
var people = Human{Name:"zhangsan"}
普通佔位符
佔位符 說明 舉例 輸出
%v 相應值的預設格式。 Printf("%v", people) {zhangsan},
%+v 列印結構體時,會新增欄位名 Printf("%+v", people) {Name:zhangsan}
%#v 相應值的Go語法表示 Printf("#v", people) main.Human{Name:"zhangsan"}
%T 相應值的型別的Go語法表示 Printf("%T", people) main.Human
%% 字面上的百分號,並非值的佔位符 Printf("%%") %
布林佔位符
佔位符 說明 舉例 輸出
%t true 或 false。 Printf("%t", true) true
整數佔位符
佔位符 說明 舉例 輸出
%b 二進位制表示 Printf("%b", 5) 101
%c 相應Unicode碼點所表示的字元 Printf("%c", 0x4E2D) 中
%d 十進位制表示 Printf("%d", 0x12) 18
%o 八進位制表示 Printf("%d", 10) 12
%q 單引號圍繞的字元字面值,由Go語法安全地轉義 Printf("%q", 0x4E2D) '中'
%x 十六進位制表示,字母形式為小寫 a-f Printf("%x", 13) d
%X 十六進位制表示,字母形式為大寫 A-F Printf("%x", 13) D
%U Unicode格式:U+1234,等同於 "U+%04X" Printf("%U", 0x4E2D) U+4E2D
浮點數和複數的組成部分(實部和虛部)
佔位符 說明 舉例 輸出
%b 無小數部分的,指數為二的冪的科學計數法,
與 strconv.FormatFloat 的 'b' 轉換格式一致。例如 -123456p-78
%e 科學計數法,例如 -1234.456e+78 Printf("%e", 10.2) 1.020000e+01
%E 科學計數法,例如 -1234.456E+78 Printf("%e", 10.2) 1.020000E+01
%f 有小數點而無指數,例如 123.456 Printf("%f", 10.2) 10.200000
%g 根據情況選擇 %e 或 %f 以產生更緊湊的(無末尾的0)輸出 Printf("%g", 10.20) 10.2
%G 根據情況選擇 %E 或 %f 以產生更緊湊的(無末尾的0)輸出 Printf("%G", 10.20+2i) (10.2+2i)
字串與位元組切片
佔位符 說明 舉例 輸出
%s 輸出字串表示(string型別或[]byte) Printf("%s", []byte("Go語言")) Go語言
%q 雙引號圍繞的字串,由Go語法安全地轉義 Printf("%q", "Go語言") "Go語言"
%x 十六進位制,小寫字母,每位元組兩個字元 Printf("%x", "golang") 676f6c616e67
%X 十六進位制,大寫字母,每位元組兩個字元 Printf("%X", "golang") 676F6C616E67
指標
佔位符 說明 舉例 輸出
%p 十六進位制表示,字首 0x Printf("%p", &people) 0x4f57f0
其它標記
佔位符 說明 舉例 輸出
+ 總列印數值的正負號;對於%q(%+q)保證只輸出ASCII編碼的字元。
Printf("%+q", "中文") "\u4e2d\u6587"
- 在右側而非左側填充空格(左對齊該區域)
# 備用格式:為八進位制新增前導 0(%#o) Printf("%#U", '中') U+4E2D
為十六進位制新增前導 0x(%#x)或 0X(%#X),為 %p(%#p)去掉前導 0x;
如果可能的話,%q(%#q)會列印原始 (即反引號圍繞的)字串;
如果是可列印字元,%U(%#U)會寫出該字元的
Unicode 編碼形式(如字元 x 會被列印成 U+0078 'x')。
' ' (空格)為數值中省略的正負號留出空白(% d);
以十六進位制(% x, % X)列印字串或切片時,在位元組之間用空格隔開
0 填充前導的0而非空格;對於數字,這會將填充移到正負號之後
golang沒有 %u
點位符,若整數為無符號型別,預設就會被列印成無符號的。
寬度與精度的控制格式以Unicode
碼點為單位。寬度為該數值佔用區域的最小寬度;精度為小數點之後的位數。
運算元的型別為int
時,寬度與精度都可用字元 *
表示。
對於 %g
/ %G
而言,精度為所有數字的總數,例如:123.45,%.4g 會列印123.5,(而 %6.2f 會列印123.45)。
%e
和 %f
的預設精度為6
對大多數的數值型別而言,寬度為輸出的最小字元數,如果必要的話會為已格式化的形式填充空格。
而以字串型別,精度為輸出的最大字元數,如果必要的話會直接截斷。
本作品採用《CC 協議》,轉載必須註明作者和本文連結