站长资讯网
最全最丰富的资讯网站

关于 Golang 字符串 格式化

下面由golang教程栏目给大家介绍Golang 字符串 格式化,希望对需要的朋友有所帮助!

关于 Golang 字符串 格式化

golang format

在 Go 语言中,fmt.Sprintf(), fmt.Printf(), fmt.Fprintf(), Log.Printf(), log.Panicf() 等函数常常会用字符串格式化参数,这一篇文章带你熟悉所有参数。

参数介绍

动 词 功 能
%v 按值的本来值输出
%+v 在 %v 基础上,对结构体字段名和值进行展开
%#v 输出 Go 语言语法格式的值
%T 输出 Go 语言语法格式的类型和值
%% 输出 % 本体
%b 整型以二进制方式显示
%o 整型以八进制方式显示
%d 整型以十进制方式显示
%x 整型以十六进制方式显示
%X 整型以十六进制、字母大写方式显示
%U Unicode 字符
%f 浮点数
%p 指针,十六进制方式显示

实战例子

package mainimport "fmt"import "os"type point struct {     x, y int}func main() {      // Go 为常规 Go 值的格式化设计提供了多种打印方式。例     // 如,这里打印了 `point` 结构体的一个实例。     p := point{1, 2}     fmt.Printf("%vn", p)     // 输出:{1 2}      // 如果值是一个结构体,`%+v` 的格式化输出内容将包括     // 结构体的字段名。     fmt.Printf("%+vn", p)     // 输出:{x:1 y:2}      // `%#v` 形式则输出这个值的 Go 语法表示。例如,值的     // 运行源代码片段。     fmt.Printf("%#vn", p)     // 输出:main.point{x:1, y:2}      // 需要打印值的类型,使用 `%T`。     fmt.Printf("%Tn", p)     // 输出:main.point      // 格式化布尔值是简单的。     fmt.Printf("%tn", true)     // 输出:true      // 格式化整形数有多种方式,使用 `%d`进行标准的十进     // 制格式化。     fmt.Printf("%dn", 123)     // 输出:123      // 这个输出二进制表示形式。     fmt.Printf("%bn", 14)     // 输出:1110      // 这个输出给定整数的对应字符。     fmt.Printf("%cn", 33)     // 输出:!      // `%x` 提供十六进制编码。     fmt.Printf("%xn", 456)     // 输出:1c8      // 对于浮点型同样有很多的格式化选项。使用 `%f` 进     // 行最基本的十进制格式化。     fmt.Printf("%fn", 78.9)     // 输出:78.900000      // `%e` 和 `%E` 将浮点型格式化为(稍微有一点不     // 同的)科学技科学记数法表示形式。     fmt.Printf("%en", 123400000.0)     // 输出:1.234000e+08     fmt.Printf("%En", 123400000.0)     // 输出:1.234000E+08      // 使用 `%s` 进行基本的字符串输出。     fmt.Printf("%sn", ""string"")     // 输出:"string"      // 像 Go 源代码中那样带有双引号的输出,使用 `%q`。     fmt.Printf("%qn", ""string"")     // 输出:""string""      // 和上面的整形数一样,`%x` 输出使用 base-16 编码的字     // 符串,每个字节使用 2 个字符表示。     fmt.Printf("%xn", "hex this")     // 输出:6865782074686973      // 要输出一个指针的值,使用 `%p`。     fmt.Printf("%pn", &p)     // 输出:0x42135100      // 当输出数字的时候,你将经常想要控制输出结果的宽度和     // 精度,可以使用在 `%` 后面使用数字来控制输出宽度。     // 默认结果使用右对齐并且通过空格来填充空白部分。     fmt.Printf("|%6d|%6d|n", 12, 345)     // 输出:|    12|   345|      // 你也可以指定浮点型的输出宽度,同时也可以通过 宽度.     // 精度 的语法来指定输出的精度。     fmt.Printf("|%6.2f|%6.2f|n", 1.2, 3.45)     // 输出:|  1.20|  3.45|      // 要左对齐,使用 `-` 标志。     fmt.Printf("|%-6.2f|%-6.2f|n", 1.2, 3.45)     // 输出:|1.20  |3.45  |      // 你也许也想控制字符串输出时的宽度,特别是要确保他们在     // 类表格输出时的对齐。这是基本的右对齐宽度表示。     fmt.Printf("|%6s|%6s|n", "foo", "b")     // 输出:|   foo|     b|      // 要左对齐,和数字一样,使用 `-` 标志。     fmt.Printf("|%-6s|%-6s|n", "foo", "b")     // 输出:|foo   |b     |      // 到目前为止,我们已经看过 `Printf`了,它通过 `os.Stdout`     // 输出格式化的字符串。`Sprintf` 则格式化并返回一个字     // 符串而不带任何输出。     s := fmt.Sprintf("a %s", "string")     fmt.Println(s)     // 输出:a string      // 你可以使用 `Fprintf` 来格式化并输出到 `io.Writers`     // 而不是 `os.Stdout`。     fmt.Fprintf(os.Stderr, "an %sn", "error")     // 输出:an error}
  • 结果
{1 2} {x:1 y:2} main.point{x:1, y:2} main.point true 123 1110 ! 1c8 78.900000 1.234000e+08 1.234000E+08 "string" ""string"" 6865782074686973 0xc000100010 |    12|   345| |  1.20|  3.45| |1.20  |3.45  | |   foo|     b| |foo   |b     | a string an error

赞(0)
分享到: 更多 (0)
网站地图   沪ICP备18035694号-2    沪公网安备31011702889846号