文本处理

概述

参考:

格式化输出

表格一样输出数据,有多个包可以实现这种效果:

格式化占位符

参考:

格式化占位符,也可以称为 format verbs(格式化动词)。这些动词可以在输出时,告诉数据应该以什么类型、样式输出。这类似于 C 语言的 printf 和 scanf,但是更简洁。

以下面的代码为例:

type Human struct {
    Name string
}
var people = Human{Name:"zhangsan"}

普通占位符

占位符说明举例输出
%v根据值来自动推断类型的默认格式Printf("%v", people){zhangsan},
%+v打印结构体时,会添加字段名Printf("%+v", people){Name:zhangsan}
%#v相应值的 Go 语法表示Printf("#v", people)main.Human{Name:“zhangsan”}
%T相应值的类型的 Go 语法表示Printf("%T", people)main.Human
%%字面上的百分号,并非值的占位符Printf("%%")%

布尔占位符

占位符说明举例输出
%ttrue 或 false。Printf("%t", true)true

整数占位符

占位符说明举例输出
%b二进制表示Printf("%b", 5)101
%c相应 Unicode 码点所表示的字符Printf("%c", 0x4E2D)
%d十进制表示Printf("%d", 0x12)18
%o八进制表示Printf("%d", 10)12
%q将字符串格式化为带有双引号的字符串。并用双引号将整个字符串包裹起来,
若字符串中有特殊字符,则会被安全得转义为 16 进制或其他表示法。
Printf("%q", 0x4E2D)‘中’
%x十六进制表示,字母形式为小写 a-fPrintf("%x", 13)d
%X十六进制表示,字母形式为大写 A-FPrintf("%x", 13)D
%UUnicode 格式:U+1234,等同于 “U+%04X”Printf("%U", 0x4E2D)U+4E2D

浮点数和复数的组成部分(实部和虚部)

占位符说明举例输出
%b无小数部分的,指数为二的幂的科学计数法,与 strconv.FormatFloat 的 ‘b’ 转换格式一致。-123456p-78
%e科学计数法,例如 -1234.456e+78Printf("%e", 10.2)1.020000e+01
%E科学计数法,例如 -1234.456E+78Printf("%e", 10.2)1.020000E+01
%f有小数点而无指数,例如 123.456Printf("%f", 10.2)10.200000
%g根据情况选择 %e 或 %f 以产生更紧凑的(无末尾的 0)输出Printf("%g", 10.20)10.2
%G根据情况选择 %E 或 %f 以产生更紧凑的(无末尾的 0)输出Printf("%G", 10.20+2i)(10.2+2i)

%2.f 可以保留小数点后两位,修改数字以确定要保留小数点后的位数

字符串与字节切片

占位符说明举例输出
%s输出字符串表示(string 类型或[]byte)Printf("%s", []byte(“Go 语言”))Go 语言
%q双引号围绕的字符串,由 Go 语法安全地转义Printf("%q", “Go 语言”)“Go 语言”
%x十六进制,小写字母,每字节两个字符Printf("%x", “golang”)676f6c616e67
%X十六进制,大写字母,每字节两个字符Printf("%X", “golang”)676F6C616E67

指针

占位符说明举例输出
%p十六进制表示,前缀 0xPrintf("%p", &people)0x4f57f0

其它标记

占位符说明举例输出
+总打印数值的正负号;对于%q(%+q)保证只输出 ASCII 编码的字符。Printf("%+q", “中文”)“\u4e2d\u6587”
-在右侧而非左侧填充空格(左对齐该区域)
#备用格式:为八进制添加前导 0(%#o)Printf("%#U", ‘中’)U+4E2D
为十六进制添加前导 0x(%#x)或 0X(%#X),为 %p(%#p)去掉前导 0x;
如果可能的话,%q(%#q)会打印原始 (即反引号围绕的)字符串;
如果是可打印字符,%U(%#U)会写出该字符的 Unicode 编码形式(如字符 x 会被打印成 U+0078 ‘x’)。
’ '(空格)为数值中省略的正负号留出空白(% d);以十六进制(% x, % X)打印字符串或切片时,在字节之间用空格隔开
0填充前导的 0 而非空格;对于数字,这会将填充移到正负号之后

golang 没有 ‘%u’ 点位符,若整数为无符号类型,默认就会被打印成无符号的。

宽度与精度的控制格式以 Unicode 码点为单位。宽度为该数值占用区域的最小宽度;精度为小数点之后的位数。

操作数的类型为 int 时,宽度与精度都可用字符*表示。

对于 %g/%G 而言,精度为所有数字的总数,例如:123.45,%.4g 会打印 123.5,(而 %6.2f 会打印 123.45)。

%e 和 %f 的默认精度为 6

对大多数的数值类型而言,宽度为输出的最小字符数,如果必要的话会为已格式化的形式填充空格。

而以字符串类型,精度为输出的最大字符数,如果必要的话会直接截断。

文本解析

YAML

参考:

YAML 数据解析

YAML解析库 沿用了 JSON解析库 的相关说法。

package main

import (
	"fmt"
	"io/ioutil"
	"log"

	"gopkg.in/yaml.v2"
)

//Nginx nginx  配置
type Nginx struct {
	Port    int    `yaml:"Port"`
	LogPath string `yaml:"LogPath"`
	Path    string `yaml:"Path"`
}

//Config   系统配置配置
type Config struct {
	Name      string `yaml:"SiteName"`
	Addr      string `yaml:"SiteAddr"`
	HTTPS     bool   `yaml:"Https"`
	SiteNginx Nginx  `yaml:"Nginx"`
}

func main() {
	var setting Config
	config, errRead := ioutil.ReadFile("./info.yaml")
	if errRead != nil {
		fmt.Print(errRead)
	}
	errUnmarshal := yaml.Unmarshal(config, &setting)
	if errUnmarshal != nil {
		log.Fatalf("error: %v", errUnmarshal)
	}

	fmt.Println(setting)
	fmt.Println(setting.Name)
	fmt.Println(setting.Addr)
	fmt.Println(setting.HTTPS)
	fmt.Println(setting.SiteNginx.Port)
	fmt.Println(setting.SiteNginx.LogPath)
	fmt.Println(setting.SiteNginx.Path)
}

JSON

JSON

TOML


最后修改 September 25, 2025: clearup k8s api (b30dd462)