标签:
Package fmt
fmt 包实现了格式化I/O函数,类似于C的 printf 和 scanf. 格式“占位符”衍生自C,但比C更简单。
占位符 | 功能 |
---|---|
%v | 相应值的默认格式。在打印结构体时,“加号”标记(%+v)会添加字段名 |
%#v | 相应值的Go语法表示 |
%T | 相应值的类型的Go语法表示 |
%% | 字面上的百分号,并非值的占位符 |
占位符 | 功能 |
---|---|
%t | 单词 true 或 false |
占位符 | 功能 |
---|---|
%b | 二进制表示 |
%c | 相应Unicode码点所表示的字符 |
%d | 十进制表示 |
%o | 八进制表示 |
%q | 单引号围绕的字符字面值,由Go语法安全地转义 |
%x | 十六进制表示,字母形式为小写 a-f |
%X | 十六进制表示,字母形式为大写 A-F |
%U | Unicode格式:U+1234,等同于 U+%04X |
占位符 | 功能 |
---|---|
%b | 无小数部分的,指数为二的幂的科学计数法,与strconv.FormatFloat的 ‘b’ 转换格式一致。例如 -123456p-78 |
%e | 科学计数法,例如 -1234.456e+78 |
%E | 科学计数法,例如 -1234.456E+78 |
%f | 有小数点而无指数,例如 123.456 |
%g | 根据情况选择 %e 或 %f 以产生更紧凑的(无末尾的0)输出 |
%G | 根据情况选择 %E 或 %f 以产生更紧凑的(无末尾的0)输出 |
占位符 | 功能 |
---|---|
%s | 字符串或切片的无解译字节 |
%q | 双引号围绕的字符串,由Go语法安全地转义 |
%x | 十六进制,小写字母,每字节两个字符 |
%X | 十六进制,大写字母,每字节两个字符 |
占位符 | 功能 |
---|---|
%p | 十六进制表示,前缀 0x |
注意:
这里没有 ‘u’ 标记。若整数为无符号类型,他们就会被打印成无符号的。类似地, 这里也不需要指定操作数的大小(int8,int64)。
宽度与精度的控制格式以Unicode码点为单位。(这点与C的 printf 不同, 它以字节数为单位。)二者或其中之一均可用字符 ‘*’ 表示, 此时它们的值会从下一个操作数中获取,该操作数的类型必须为 int。
对数值而言,宽度为该数值占用区域的最小宽度;精度为小数点之后的位数。 但对于 %g/%G 而言,精度为所有数字的总数。例如,对于123.45,格式 %6.2f 会打印123.45,而 %.4g 会打印123.5。%e 和 %f 的默认精度为6;但对于 %g 而言, 它的默认精度为确定该值所必须的最小位数。
对大多数值而言,宽度为输出的最小字符数,如果必要的话会为已格式化的形式填充空格。 对字符串而言,精度为输出的最大字符数,如果必要的话会直接截断。
+
总打印数值的正负号;对于%q(%+q)保证只输出ASCII编码的字符。
-
在右侧而非左侧填充空格(左对齐该区域)
var i interface{} = 23
fmt.Printf("%v\n", i)
会打印 23。
若其格式(它对于 Println 等函数是隐式的 %v)对于字符串是有效的 (%s %q %v %x %X),以下两条规则也适用:
若一个操作数实现了 error 接口,Error 方法就能将该对象转换为字符串, 随后会根据占位符的需要进行格式化。
若一个操作数实现了 String() string 方法,该方法能将该对象转换为字符串, 随后会根据占位符的需要进行格式化。
标签:
原文地址:http://www.cnblogs.com/reposkeeper/p/Go-biao-zhun-ku-fmt.html