深入了解Golang中的格式化输出

fmt

Go语言用于控制文本输出常用的标准库是fmt

fmt中主要用于输出的函数有:

  • Print: 输出到控制台,不接受任何格式化操作
  • Println: 输出到控制台并换行
  • Printf: 格式化输出,只可以打印出格式化的字符串,只可以直接输出字符串类型的变量(不可以直接输出别的类型)
  • Sprintf: 格式化并返回一个字符串而不带任何输出
  • Fprintf: 来格式化并输出到io.Writers而不是os.Stdout

格式化

通过Printf函数来测试下Go语言里面的字符串格式化:

fmt.Sprintf(格式化样式, 参数列表…)

格式样式: 字符串形式,格式化符号以%开头,%s字符串格式,%d十进制的整数格式

参数列表: 多个参数以逗号分隔,个数必须与格式化样式中的个数一一对应,否则运行时会报错

比如:

username := "boy"
fmt.Printf("welcome, %s", username)

整数格式化

占 位 符 描 述
%b 整数以二进制方式显示
%o 整数以八进制方式显示
%d 整数以十进制方式显示
%x 整数以十六进制方式显示
%X 整数以十六进制、字母大写方式显示
%c 相应Unicode码点所表示的字符
%U Unicode字符,Unicode格式:123,等同于“U+007B”
func main() {
    fmt.Printf("%b \n", 123) //1111011
    fmt.Printf("%o \n", 123) //173
    fmt.Printf("%d \n", 123) //123
    fmt.Printf("%x \n", 123) //7b
    fmt.Printf("%X \n", 123) //7B   
    fmt.Printf("%c \n", 123) //{
    fmt.Printf("%U \n", 123) //U+007B 
}

浮点数格式化

占 位 符 描 述
%e 科学计数法,例如 1.234560e+02
%E 科学计数法,例如 1.234560E+02
%f 有小数点而无指数,例如 123.456
%F 等价于%f
%g 根据情况选择 %e 或 %f 以产生更紧凑的(无末尾的0)输出
%G 根据情况选择 %E 或 %F 以产生更紧凑的(无末尾的0)输出
func main() {
    fmt.Printf("%e \n", 123.456) //1.234560e+02
    fmt.Printf("%E \n", 123.456) //1.234560E+02
    fmt.Printf("%f \n", 123.456) //123.456000
    fmt.Printf("%F \n", 123.456) //123.456000
    fmt.Printf("%g \n", 123.456) //123.456
    fmt.Printf("%G \n", 123.456) //123.456 
}

布尔类型格式化

占 位 符 描 述
%t true 或 false
func main() {
    fmt.Printf("%t", true) //true
}

字符格式化

占 位 符 描 述
%c 相应Unicode码点所表示的字符
func main() {
    fmt.Printf("%c", 0x4E2D) //中
}

字符串格式化

占 位 符 描 述
%s 直接输出字符串或者[]byte
%q 双引号围绕的字符串,由Go语法安全地转义
%x 每个字节用两字符十六进制数表示(使用a-f)
%X 每个字节用两字符十六进制数表示(使用A-F)
func main() {
    fmt.Printf("%s \n", "Hello world") //Hello world
    fmt.Printf("%q \n", "Hello world") //"Hello world"
    fmt.Printf("%x \n", "Hello world") //48656c6c6f20776f726c64
    fmt.Printf("%X \n", "Hello world") //48656C6C6F20776F726C64
}

指针格式化

占 位 符 描 述
%p 表示为十六进制,并加上前导的0x
%#p 表示为十六进制,没有前导的0x
func main() {
    a := "Hello world"
    b := &a
    fmt.Printf("%p \n", b)  //0xc000046230
    fmt.Printf("%#p \n", b) //c000046230
}

通用占位符

占 位 符 描 述
%v 值的默认格式
%+v 类似%v,但输出结构体时会添加字段名
%#v 相应值的Go语法表示
%T 相应值的类型的Go语法表示
%% 百分号,字面上的%,非占位符含义
func main() {
    fmt.Printf("%v \n", "Hello World")   //Hello World
    fmt.Printf("%+v \n", "Hello World")  //Hello World
    fmt.Printf("%#v \n", "Hello World")  //"Hello World"
    fmt.Printf("%T \n", "Hello World")   //string
    fmt.Printf("%%%v \n", "Hello World") //%Hello World
}

宽度表示

浮点数精度控制

宽度通过一个紧跟在百分号后面的十进制数指定,如果未指定宽度,则表示值时除必需之外不作填充。

精度通过(可选的)宽度后跟点号后跟的十进制数指定。如果未指定精度,会使用默认精度;如果点号后没有跟数字,表示精度为0。举例如下

func main() {
    fmt.Printf("|%f|\n", 123.456)     //|123.456000|
    fmt.Printf("|%12f|\n", 123.456)   //|  123.456000|
    fmt.Printf("|%.3f|\n", 123.456)   //|123.456|
    fmt.Printf("|%12.3f|\n", 123.456) //|     123.456|
    fmt.Printf("|%12.f|\n", 123.456)  //|         123|
}

字符串长度控制

宽度设置格式:占位符中间加一个数字, 数字分正负, +: 右对齐, -: 左对齐

最小宽度:百分号后紧跟十进制数,不够部分可以选择补0

最大宽度:小数点后的十进制数,超出的部分会被截断

func main() {
    fmt.Printf("|%s|\n", "123.456")    //|123.456|
    fmt.Printf("|%12s|\n", "123.456")  //|     123.456|
    fmt.Printf("|%-12s|\n", "123.456") //|123.456     |
    fmt.Printf("|%012s|\n", "123.456") //|00000123.456|
    fmt.Printf("|%.5s|\n", "123.456")  //|123.4|
}

到此这篇关于深入了解Golang中的格式化输出的文章就介绍到这了,更多相关Golang格式化输出内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

你可能感兴趣的:(深入了解Golang中的格式化输出)