Go 语言中 20 个占位符的整理

目录
  • 一、概念
  • 二、哪些函数支持
  • 三、占位符使用
  • 四、普通占位符
    • 1. %v、%+v、%#v
    • 2. %T
    • 3. %%
  • 五、布尔占位符
  • 六、整数占位符
    • 1. %b
    • 2. %c
    • 3. %d、%5d、%-5d、%05d
    • 4. %o、%#o
    • 5. %q
    • 6. %x、%#x
    • 7. %X、%#X
    • 8. %U、%#U
  • 七、浮点数与复数
    • 1. %b
    • 2. %e、%E
    • 3. %f、%.2f
    • 4. %g、%.3g
  • 八、字符串与字节切片
    • 1. %s
    • 2. %q
    • 3. %x、%X
  • 九、指针
  • 十、其它标记
    • 1. +
    • 2. -
    • 3.
    • 4. ' ' 空格
    • 5. 0

一、概念

什么是占位符?你就从表面意思理解,就是占位置,只不过有很多不同种类的位置,而且这个位置不是谁都能坐,是有要求的,在程序层面用于格式化数据。

二、哪些函数支持

Go 语言中,标准包 fmt 有好多格式化的工具函数,函数名末尾通常以 f 结尾,列举如下:

  • fmt.Printf 格式化字符串并打印到终端(标准输出)。
  • fmt.Sprintf 格式化字符串并返回。
  • fmt.Sscanf 从字符串中解析占位符的对应位置数据。
  • fmt.Fscanf io.Reader 类型中读取数据并解析占位符的对应位置数据,用于读取文件、终端(标准输入)。
  • fmt.Fprintf 将格式化的字符串数据输出到 io.Writer 类型中,用于输出到文件。
  • fmt.Errorf 格式化方式创建一个错误类型消息。

这块没有重点展开讲解各个函数,只是简单罗列下,如果还不明白自行查一下,也可以问我。

下来看看本篇的重点...

三、占位符使用

占位符需要使用 % 符号表示,简单展示一个。

s := fmt.Sprintf("%s真帅", "老苗")
fmt.Println(s)

// 输出
老苗真帅

%s 标示字符串,将"老苗"字符串填充到 %s 位置。下来看看到底有哪些占位符?

四、普通占位符

先创建一个数据,作为打印的对象。

type Example struct {
 Content string
}

var data = Example{Content: "例子"}

1. %v、%+v、%#v

%v:获取数据的值,如果实现了 error 接口,仅表示错误消息。

fmt.Printf("%v", data)
// 输出
{例子}

fmt.Printf("%v", errors.New("我错了"))
// 输出
我错了

%+v:获取数据的值,如果结构体,会携带字段名。

fmt.Printf("%+v", data)
// 输出
{Content:例子}

%#v:获取数据的值,如果是结构体,会携带结构体名和字段名。

fmt.Printf("%#v", data)
// 输出
main.Example{Content:"例子"}

2. %T

获取数据类型

fmt.Printf("%T", data)
// 输出
main.Example

3. %%

字面上的一个百分号。

fmt.Printf("%%")
// 输出
%

五、布尔占位符

%t

true 或 false。

fmt.Printf("%t", true)
// 输出
true

六、整数占位符

1. %b

二进制。

fmt.Printf("%b", 4)
// 输出
100

2. %c

Unicode 码转字符。

fmt.Printf("%c", 0x82d7)
// 输出
苗

3. %d、%5d、%-5d、%05d

十进制整数表示。

fmt.Printf("%d,%d,%d", 10, 010, 0x10)
// 输出
10,8,16

三个数据: 10 十进制, 010 八进制, 0x10 十六进制

占位符还可以指定最小宽度,格式如下:

%5d
%-5d
%05d

例:

fmt.Printf("|%5d|%-5d|%05d|", 1, 1, 1)
// 输出
|    1|1    |00001|

4. %o、%#o

八进制表示

fmt.Printf("%o,%o,%o", 10, 010, 0x10)
// 输出
12,10,20

在很多开发语言中,0 打头的数字都表示八进制。通过 %#o 输出带 0 开头。

fmt.Printf("\n%#o\n", 10)
// 输出
012

5. %q

%c 类似,都是 Unicode 码转字符,只是结果多了单引号。

fmt.Printf("%q", 0x82d7)
// 输出
'苗'

汉字对应表: http://www.chi2ko.com/tool/CJK.htm

6. %x、%#x

十六进制表示,字母形式为小写 a-f, %#x 输出带 0x 开头。

fmt.Printf("%x, %#x", 13, 13)
// 输出
d, 0xd

7. %X、%#X

十六进制表示,字母形式为小写 A-F, %#X 输出带 0X 开头。

fmt.Printf("%X, %#X", 13, 13)
// 输出
D, 0XD

8. %U、%#U

%U:转化为 Unicode 格式规范。

fmt.Printf("%U", 0x82d7)
// 输出
U+82D7

%#U:转化为 Unicode 格式并带上对应的字符。

fmt.Printf("%#U", 0x82d7)
// 输出
U+82D7 '苗'

七、浮点数与复数

1. %b

浮点数转化为 2 的幂的科学计数法。

fmt.Printf("%b", 0.1)
// 输出
7205759403792794p-56

2. %e、%E

10 的幂的科学计数法。

fmt.Printf("%e", 10.2)
// 输出
1.020000e+01
fmt.Printf("%E", 10.2)
// 输出
1.020000E+01
区别: %e 与 %E 输出时的大小写之分。

3. %f、%.2f

浮点数, %.2f 表示保留 2 位小数, %f 默认保留 6 位, %f%F 等价。

保留的规则我现在还没有搞清楚,有时候符合四舍五入,有时候不符合,容我下来研究下,再告诉大家。

fmt.Printf("%f", 10.2)
// 输出
10.200000

fmt.Printf("%.2f|%.2f", 10.232, 10.235)
// 输出
10.23|10.23

也可以加入最小宽度,如下:

  • %9.2f 宽度最小为 9,包含小数位在内,精度为 2。
  • %9.f %9f 宽度最小为 9。

4. %g、%.3g

根据情况选择 %e%f ,但末尾去除 0。

%f 情况如下:

fmt.Printf("%g|%g", 10.20, 1.200000+3.400000i)
// 输出
10.2|(1.2+3.4i)

%e 情况如下:

fmt.Printf("%g|%g", 2e2, 2E2)
// 输出
200|200

%.3g 表示的不是小数保留 3 位,而是只保留 3 个数字。

fmt.Printf("%.3g", 12.34)
// 输出
12.3

思考:官网中 %g 和 %G 是有区别的,但我测试下来是等价的,可能我的测试有问题,我给出官网文档,如下:

%g %e for large exponents, %f otherwise. Precision is discussed below.
%G %E for large exponents, %F otherwise

八、字符串与字节切片

1. %s

字符串或字节切片

fmt.Printf("%s|%s", "老苗", []byte("嘿嘿嘿"))
// 输出
老苗|嘿嘿嘿

2. %q

有 Go 语言安全转义,双引号包裹。

fmt.Printf("%q", "老苗")
// 输出
"老苗"

3. %x、%X

十六进制, %x 小写字母 a - f, %X 大写字母 A - F。

fmt.Printf("%x|%X", "苗", "苗")
// 输出
e88b97|E88B97

九、指针

%p、%#p

地址,使用十六进制表示, %p 带 0x, %#p 不带。

num := 2
s := []int{1, 2}
fmt.Printf("%p|%p", &num, s)

// 输出
0xc00000a1d0|0xc00000a1e0

十、其它标记

1. +

打印数值的正负号,对于 %+q ,只输出 ASCII 编码的字符,如果非 ASCII 编码,则转成 Unicode 编码输出。

fmt.Printf("%+d|%+d", 2, -2)
// 输出
+2|-2

fmt.Printf("%+q|%+q", "miao","苗")
// 输出
"miao"|"\u82d7"

2. -

在右侧填充空格,这块就不举例了,使用如 %-5d ,浮点 %-9.2f 也支持,其它占位符大家可以有兴趣自行实验。

3.

  • 为八进制添加前导 0,上面已举例。
  • 为十六进制添加前导 0x 或 0X,上面已举例。
  • %#p去掉 0x。
  • %+q 打印字符串时使用反引号包裹。
fmt.Printf("%#q", "苗")
// 输出
`苗`

%#U 打印编码时,带上字符,上面已举例。

4. ' ' 空格

为正负号留出空白位置。

fmt.Printf("|% d|", 2)
// 输出
| 2|

5. 0

填充前导的 0,对于数字会移到正负号之后,非数字也可使用。

fmt.Printf("%05s", "a")
// 输出
0000a

fmt.Printf("%+05d", 1)
// 输出
+0001

精度截断字符串

给字符串使用精度,用来截断字符串。

fmt.Printf("%.2s", "abc")
// 输出
ab

总结
占位符区分大小写,总共讲了 20 个,但占位符相关的知识点其实还有,我暂时也不想研究了,因为在项目中也很难使用到。

如果有兴趣的,前往官网。地址: https://pkg.go.dev/fmt

到此这篇关于Go 语言中 20 个占位符的整理的文章就介绍到这了,更多相关Go 语言中 20 个占位符内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • Go语言编程中字符串切割方法小结

    1.func Fields(s string) []string,这个函数的作用是按照1:n个空格来分割字符串最后返回的是 []string的切片 复制代码 代码如下: import (  "fmt"  "strings" ) func main() {  fmt.Println(strings.Fields("hello widuu golang")) //out  [hello widuu golang] } 2.func FieldsFun

  • Go 语言中 20 个占位符的整理

    目录 一.概念 二.哪些函数支持 三.占位符使用 四.普通占位符 1. %v.%+v.%#v 2. %T 3. %% 五.布尔占位符 六.整数占位符 1. %b 2. %c 3. %d.%5d.%-5d.%05d 4. %o.%#o 5. %q 6. %x.%#x 7. %X.%#X 8. %U.%#U 七.浮点数与复数 1. %b 2. %e.%E 3. %f.%.2f 4. %g.%.3g 八.字符串与字节切片 1. %s 2. %q 3. %x.%X 九.指针 十.其它标记 1. + 2.

  • c语言中abs()和fabs()的区别点整理

    (1)abs()是对整数取绝对值, 而fabs()是对浮点数取绝对值. (2)函数原型: int abs(int x) double fabs(double x) (3)头文件: abs(): #include <stdlib.h> fabs(): #include <math.h> c语言fabs是什么意思? fabs函数是一个求绝对值的函数,求出x的绝对值,和数学上的概念相同,函数原型是extern float fabs(float x),用法是#include <mat

  • C++语言中std::array的用法小结(神器用法)

    摘要:在这篇文章里,将从各个角度介绍下std::array的用法,希望能带来一些启发. td::array是在C++11标准中增加的STL容器,它的设计目的是提供与原生数组类似的功能与性能.也正因此,使得std::array有很多与其他容器不同的特殊之处,比如:std::array的元素是直接存放在实例内部,而不是在堆上分配空间:std::array的大小必须在编译期确定:std::array的构造函数.析构函数和赋值操作符都是编译器隐式声明的--这让很多用惯了std::vector这类容器的程

  • C语言中%c与%s的区别与划分详解

    %c格式对应的是单个字符,%s格式对应的是字符串. 例: char a; char b[20]; scanf("%c",&a); //只能输入一个字符. scanf("%s",b); //可以输入一串不超过20字符的字符串. %c对应类型为char, %s对应类型为char * , 即字符串. 用作输入时, 二者参数都要传char * 型. %c输入函数只会对一个字节空间赋值. 而%s会一直赋值,直到输入中遇到空白字符为止. 用作输出时, %c传char类型

  • go语言中的Carbon库时间处理技巧

    go语言之Carbon库 carbon是一个时间扩展库,它提供了易于使用接口. 简单示例: package main import ( "fmt" "github.com/uniplaces/carbon" "time" ) func main() { // 打印当前时间 now :=carbon.Now().DateTimeString() fmt.Println("本地时间:", now) Japantoday, _ :=

  • 详解C++语言中std::array的神奇用法

    概述 std::array是在C++11标准中增加的STL容器,它的设计目的是提供与原生数组类似的功能与性能.也正因此,使得std::array有很多与其他容器不同的特殊之处,比如:std::array的元素是直接存放在实例内部,而不是在堆上分配空间:std::array的大小必须在编译期确定:std::array的构造函数.析构函数和赋值操作符都是编译器隐式声明的--这让很多用惯了std::vector这类容器的程序员不习惯,觉得std::array不好用.但实际上,std::array的威力

  • C语言中 printf 函数输出格式

    printf()函数是格式化输出函数, 一般用于向标准输出设备(例如屏幕)按规定格式输出信息. 一.Printf输出格式 1.输出十进制整数 int main() { //输出十进制整数%d printf("输出的数字是:%d",666); return 0; }//结果是666 2.输出八进制整数 int main() { //输出八进制整数%o printf("输出的数字是:%o",66); return 0; }//结果是102 3.输出十六进制整数 int

  • 深入了解C语言中的const和指针

    目录 前言 指针的赋值 问题 ANSI C 有关简单赋值的标准 问题解决 const修饰 const修饰变量 const修饰指针 前言 文章内容由阅读<C专家编程>整理而来.希望可以帮助大家解决在指针赋值和const方面的问题,也希望大家多多指正文章中的错误,共同进步. 指针的赋值 问题 将一个类型为 char** 的值赋值给一个 const char** 类型的对象是否合法呢? 先说结果,在vs的环境下,编译器不会报错也不会有任何警告. 但在linux环境下用gcc编译就会出现下面的警告:

  • go语言中的return语句

    目录 1.基本语法和说明 2.函数的递归调用 2.1基本介绍 2.2递归调用入门 3.总结 1.基本语法和说明 在 Go 语言 中,跳转控制语句除了有 goto .break 和 continue 之外,还可以使用 return .如果 return 语句使用在普通的 函数 中,则表示跳出该函数,不再执行函数中 return 后面的代码,可以理解成终止函数.如果 return 语句使用在 main 函数中,表示终止 main 函数,也就是终止程序的运行. go函数支持返回多个值,这一点是其他编程

  • 详解Go语言中for循环,break和continue的使用

    目录 基本语法 有始有终的条件循环 带条件的循环 无限循环 数组循环 使用计数器循环 利用range循环 Map循环 string的遍历 Break和Continue 基本语法 和C语言同源的语法格式,有始有终的循环,for init; condition; post { } 带条件的while循环,for condition { } 无限循环,for { } 有始有终的条件循环 sum := 0 for i := 0; i < 10; i++ { sum = sum + i } 注意:i变量在

随机推荐