参数列表

General

  • %v 以默认的方式打印变量的值
  • %T 打印变量的类型

    Integer

  • %d 整型的十进制表示

  • %+d 带符号的整型,fmt.Printf(“%+d”,255)输出+255
  • %q 打印单引号
  • %o 不带0的八进制
  • %#o 带0的八进制
  • %x 小写的十六进制
  • %X 大写的十六进制
  • %#x 带0x的十六进制
  • %U 打印Unicode字符
  • %#U 打印带字符的Unicode
  • %b 打印整型的二进制

    Integet width

  • %5d 表示该整型最大的长度为5

  • %-5d 则相反,打印结果会自动左对齐
  • %05d 会在数字前面补0

    Fload

  • %f(=%.6f) 6位小数点

  • %e(=%.6e) 6位小数点(科学计数法)
  • %g 用最少的数字来表示
  • %.3g 最多3位数字来表示
  • %.3f 最多3位小数来表示

    String

  • %s 正常输出字符串

  • %q 字符串带双引号,字符串中的引号带转义符
  • %#q 字符串带反引号,如果字符串内有反引号,就用双引号代替
  • %x 将字符串转换为小写的16进制格式
  • %X 将字符串转换为大写的16进制格式
  • % x 带空格的16进制格式

    String width

  • %5s 最小宽度为5

  • %-5s 最小宽度为5(左对齐)
  • %.5s 最大宽度为5
  • %-5.7 最小宽度为5,最大宽度为7(左对齐)
  • %5.3 如果宽度大于3则截断
  • %05s 如果宽度小于5,就会在字符串前面补0

    Struct

  • %v 正常打印.比如:{sam{12345 67890}}

  • %+v 带字段名称,比如:{name:sam phone:{mobile:12345 office:67890}}
  • %#v 用Go的语法打印,例如:main.People{name:”sam”,phone:main.Phone{mobile:”12345”,office:”67890”}}

    Boolean

  • %t 打印布尔值true或者false

    Pointer

  • %p 带0x的指针

  • %#p 不带0x的指针

Println Printf Sprintf 区别

  • Println: 可以打印出字符串,和变量
  • Printf: 只可以打印出格式化的字符串,可以输出字符串类型的变量,不可以输出整形变量和整形
  • Sprintf: 则格式化并返回一个字符串而不带任何输出 ```go a := 10 fmt.Println(a)   //right fmt.Println(“abc”)  //right fmt.Printf(“%d”,a)  //right

fmt.Printf(a)  //error

s := fmt.Sprintf(“是字符串:%s”, “string”)

fmt.Println(s) // 是字符串:string

  1. <a name="hnfzr"></a>
  2. # 格式化的符号
  3. ```go
  4. /*
  5. %v 输出结构体 {10 30}
  6. %+v 输出结构体显示字段名 {one:10 tow:30}
  7. %#v 输出结构体源代码片段 main.Point{one:10, tow:30}
  8. %T 输出值的类型 main.Point
  9. %t 输出格式化布尔值 true
  10. %d`输出标准的十进制格式化 100
  11. %b`输出标准的二进制格式化 99 对应 1100011
  12. %c`输出定整数的对应字符 99 对应 c
  13. %x`输出十六进制编码 99 对应 63
  14. %f`输出十进制格式化 99 对应 63
  15. %e`输出科学技科学记数法表示形式 123400000.0 对应 1.234000e+08
  16. %E`输出科学技科学记数法表示形式 123400000.0 对应 1.234000e+08
  17. %s 进行基本的字符串输出 "\"string\"" 对应 "string"
  18. %q 源代码中那样带有双引号的输出 "\"string\"" 对应 "\"string\""
  19. %p 输出一个指针的值 &jgt 对应 0xc00004a090
  20. % 后面使用数字来控制输出宽度 默认结果使用右对齐并且通过空格来填充空白部分
  21. %2.2f 指定浮点型的输出宽度 1.2 对应 1.20
  22. %*2.2f 指定浮点型的输出宽度对齐,使用 `-` 标志 1.2 对应 *1.20
  23. */
  24. jgt := Point{10,30}
  25. fmt.Printf("%v\n",jgt) // {10 30}
  26. fmt.Printf("%+v\n",jgt) // {one:10 tow:30}
  27. fmt.Printf("%#v\n",jgt) // main.Point{one:10, tow:30}
  28. fmt.Printf("%T\n",jgt) // main.Point
  29. fmt.Printf("%t\n",true) // true
  30. fmt.Printf("%d\n",100) // 100
  31. fmt.Printf("%b\n",99) // 99 对应 1100011
  32. fmt.Printf("%c\n",99) // 99 对应 c
  33. fmt.Printf("%x\n",99) // 99 对应 63
  34. fmt.Printf("%f\n",99.9) // 99.9 对应 99.900000
  35. fmt.Printf("%e\n",123400000.0) // 123400000.0 对应 1.234000e+08
  36. fmt.Printf("%E\n",123400000.0) // 123400000.0 对应 1.234000e+08
  37. fmt.Printf("%s\n","\"string\"") // "\"string\"" 对应 "string"
  38. fmt.Printf("%q\n","\"string\"") // "\"string\"" 对应 "string"
  39. fmt.Printf("%p\n",&jgt) // &jgt 对应 0xc00004a090
  40. fmt.Printf("%6d\n",8) // &jgt 对应 0xc00004a090
  41. fmt.Printf("%2.2f\n",1.2 ) // 1.2 对应 1.20
  42. fmt.Printf("*%2.2f\n",1.2 ) // 1.2 对应 *1.20
  1. package main
  2. import "fmt"
  3. import "os"
  4. type point struct {
  5. x, y int
  6. }
  7. func main() {
  8. //Go 为常规 Go 值的格式化设计提供了多种打印方式。例如,这里打印了 point 结构体的一个实例。
  9. p := point{1, 2}
  10. fmt.Printf("%v\n", p) // {1 2}
  11. //如果值是一个结构体,%+v 的格式化输出内容将包括结构体的字段名。
  12. fmt.Printf("%+v\n", p) // {x:1 y:2}
  13. //%#v 形式则输出这个值的 Go 语法表示。例如,值的运行源代码片段。
  14. fmt.Printf("%#v\n", p) // main.point{x:1, y:2}
  15. //需要打印值的类型,使用 %T。
  16. fmt.Printf("%T\n", p) // main.point
  17. //格式化布尔值是简单的。
  18. fmt.Printf("%t\n", true)
  19. //格式化整形数有多种方式,使用 %d进行标准的十进制格式化。
  20. fmt.Printf("%d\n", 123)
  21. //这个输出二进制表示形式。
  22. fmt.Printf("%b\n", 14)
  23. //这个输出给定整数的对应字符。
  24. fmt.Printf("%c\n", 33)
  25. //%x 提供十六进制编码。
  26. fmt.Printf("%x\n", 456)
  27. //对于浮点型同样有很多的格式化选项。使用 %f 进行最基本的十进制格式化。
  28. fmt.Printf("%f\n", 78.9)
  29. //%e 和 %E 将浮点型格式化为(稍微有一点不同的)科学技科学记数法表示形式。
  30. fmt.Printf("%e\n", 123400000.0)
  31. fmt.Printf("%E\n", 123400000.0)
  32. //使用 %s 进行基本的字符串输出。
  33. fmt.Printf("%s\n", "\"string\"")
  34. //像 Go 源代码中那样带有双引号的输出,使用 %q。
  35. fmt.Printf("%q\n", "\"string\"")
  36. //和上面的整形数一样,%x 输出使用 base-16 编码的字符串,每个字节使用 2 个字符表示。
  37. fmt.Printf("%x\n", "hex this")
  38. //要输出一个指针的值,使用 %p。
  39. fmt.Printf("%p\n", &p)
  40. //当输出数字的时候,你将经常想要控制输出结果的宽度和精度,可以使用在 % 后面使用数字来控制输出宽度。默认结果使用右对齐并且通过空格来填充空白部分。
  41. fmt.Printf("|%6d|%6d|\n", 12, 345)
  42. //你也可以指定浮点型的输出宽度,同时也可以通过 宽度.精度 的语法来指定输出的精度。
  43. fmt.Printf("|%6.2f|%6.2f|\n", 1.2, 3.45)
  44. //要最对齐,使用 - 标志。
  45. fmt.Printf("|%-6.2f|%-6.2f|\n", 1.2, 3.45)
  46. //你也许也想控制字符串输出时的宽度,特别是要确保他们在类表格输出时的对齐。这是基本的右对齐宽度表示。
  47. fmt.Printf("|%6s|%6s|\n", "foo", "b")
  48. //要左对齐,和数字一样,使用 - 标志。
  49. fmt.Printf("|%-6s|%-6s|\n", "foo", "b")
  50. //到目前为止,我们已经看过 Printf了,它通过 os.Stdout输出格式化的字符串。Sprintf 则格式化并返回一个字符串而不带任何输出。
  51. s := fmt.Sprintf("a %s", "string")
  52. fmt.Println(s)
  53. //你可以使用 Fprintf 来格式化并输出到 io.Writers而不是 os.Stdout。
  54. fmt.Fprintf(os.Stderr, "an %s\n", "error")
  55. }