go 中的 fmt 占位符

2024-01-09 13:30:57

通用占位符

%v

值的默认格式表示

fmt.Printf("%v\n", 100)}//100

%+v

类似%v,但输出结构体时会添加字段名

o := struct{ name string }{"tim"}
fmt.Printf("%+v\n", o)}}
//{name:tim}

%#v

值的 Go 语法表示

o := struct{ name string }{"tim"}
fmt.Printf("%#v\n", o)  }
//struct { name string }{name:"tim"}

%T

打印值的类型

o := struct{ name string }{"tim"}
fmt.Printf("%T\n", o)  }
//struct { name string }

%%

百分号

fmt.Printf("100%%\n")  }//100%

布尔型

true 或 false

t := true
fmt.Printf("value: %t", t)

整形

%b

表示为二进制

fmt.Printf("%b\n", 65)//1000001

%c

该值对应的unicode码值

fmt.Printf("%c\n", 65)//A

%d

表示为十进制

fmt.Printf("%d\n", 65)//65

%o

表示为八进制

fmt.Printf("%o\n", 65)//101

%x

表示为十六进制,使用a-f

fmt.Printf("%x\n", 65)//41

%X

表示为十六进制,使用A-F

fmt.Printf("%X\n", 65)//41

%U

表示为Unicode格式:U+1234,等价于”U+%04X”

fmt.Printf("%U\n", 65) // U+0041

%q

该值对应的单引号括起来的go语法字符字面值必要时会采用安全的转义表示

fmt.Printf("%q\n", 65)//'A'

浮点数与复数

%b

无小数部分、二进制指数的科学计数法,如-123456p-78

fmt.Printf("%b\n", 12.34)//6946802425218990p-49

%e

科学计数法,如-1234.456e+78

fmt.Printf("%e\n", f)//1.234000e+01

%G

根据实际情况采用%E或%F格式(以获得更简洁、准确的输出)

fmt.Printf("%G\n", f)//12.34

%g

根据实际情况采用%e或%f格式(以获得更简洁、准确的输出)

fmt.Printf("%g\n", f)//12.34

%F

等价于%f

fmt.Printf("%F\n", 12.34)//12.340000

%f

有小数部分但无指数部分,如123.456

fmt.Printf("%f\n", f)//12.340000

%E

科学计数法,如-1234.456E+78

fmt.Printf("%E\n", f)//1.234000E+01

字符串和[]byte

%s

直接输出字符串或者[]byte

fmt.Printf("%s\n", "tim")//tim

%q

该值对应的双引号括起来的go语法字符串字面值,必要时会采用安全的转义表示

fmt.Printf("%q\n", "tim")//"tim"

%X

每个字节用两字符十六进制数表示(使用A-F)

fmt.Printf("%X\n", "tim")//E5BEAEE5AEA2

%x

每个字节用两字符十六进制数表示(使用a-f)

fmt.Printf("%x\n", "tim")//e5beaee5aea2

指针

%p

表示为十六进制,并加上前导的0x

t := []int{1}
fmt.Printf("value: %p", t)
// value: 0x14000190008

宽度标识符

%f

默认宽度,默认精度

v := 92873.2309837 
fmt.Printf("value: %f\n", v) 
// value: 92873.230984

%9f

宽度9,默认精度

fmt.Printf("value: %9f\n", v)
// value: 92873.230984

%9.f

宽度9,精度0

fmt.Printf("value: %9.f\n", v)
// value:     92873

%9.2f

宽度9,精度2

fmt.Printf("value: %9.2f\n", v)
// value:  92873.23

%.2f

默认宽度,精度2

fmt.Printf("value: %.2f\n", v)
// value: 92873.23

其他flag

‘+’

总是输出数值的正负号;对%q(%+q)会生成全部是ASCII字符的输出(通过转义)

v := -92873.2309837
fmt.Printf("value: %+f", v)

’ ’

对数值,正数前加空格而负数前加负号;对字符串采用%x或%X时(% x或% X)会给各打印的字节之间加空格

v := 92873.2309837
fmt.Printf("value: % f", v)

‘0’

使用0而不是空格填充,对于数值类型会把填充的0放在正负号后面

v := -92873.2309837
fmt.Printf("value: %07.f", v)
// value: -092873

‘#’

八进制数前加0(%#o),十六进制数前加0x(%#x)或0X(%#X),指针去掉前面的0x(%#p)对%q(%#q),对%U(%#U)会输出空格和单引号括起来的go字面值

v := 101
fmt.Printf("value: %#o", v)
// value: 0145

‘-’

在输出右边填充空白而不是默认的左边(即从默认的右对齐切换为左对齐)

v := 101.35345345
fmt.Printf("value: %-3.1f", v)
// value: 101.4

文章来源:https://blog.csdn.net/ldxxxxll/article/details/135477628
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。