fmt库核心是Printf、Sprintf、Fprintf函数,通过格式化动词如%v、%d、%f等控制输出;支持精度、宽度、flag等高级格式化;可通过实现Stringer接口自定义类型输出;结合json库可格式化输出JSON数据。

Golang的
fmt
库是格式化输出的核心,它提供了强大的功能,可以将各种类型的数据转换为字符串,并按照指定的格式输出到控制台或文件中。掌握
fmt
库的使用,能显著提高代码的可读性和调试效率。
解决方案:
fmt
库的核心在于
Printf
、
Sprintf
、
Fprintf
等函数。
Printf
直接输出到标准输出,
Sprintf
返回格式化后的字符串,
Fprintf
则输出到
io.Writer
接口,比如文件。
格式化动词是关键。
%v
是默认格式,
%T
输出类型,
%d
是十进制整数,
%f
是浮点数,
%s
是字符串,
%p
是指针地址。还有
%b
二进制,
%o
八进制,
%x
十六进制。
立即学习“go语言免费学习笔记(深入)”;
举个例子:
package mainimport "fmt"func main() { name := "Alice" age := 30 pi := 3.14159 fmt.Printf("Name: %s, Age: %d, Pi: %fn", name, age, pi) // 基本用法 fmt.Printf("Pi with 2 decimals: %.2fn", pi) // 精度控制 fmt.Printf("Age in binary: %bn", age) // 二进制 fmt.Printf("Type of pi: %Tn", pi) // 类型 fmt.Printf("Value of pi: %vn", pi) // 值 fmt.Printf("Default format for struct: %vn", struct{ X, Y int }{10, 20}) fmt.Printf("Detailed format for struct: %+vn", struct{ X, Y int }{10, 20}) fmt.Printf("Go syntax format for struct: %#vn", struct{ X, Y int }{10, 20}) str := fmt.Sprintf("Name: %s, Age: %d", name, age) // Sprintf 用法 fmt.Println(str)}
%+v
和
%#v
在输出结构体时很有用。
%+v
会输出字段名,
%#v
会输出Go语法格式的结构体字面量,方便复制粘贴。
如何使用fmt格式化输出JSON数据?
可以使用
encoding/json
库配合
fmt.Printf
。先将JSON数据Unmarshal到结构体或者map,然后用
fmt.Printf
和
%+v
或
%#v
输出。或者直接使用
json.MarshalIndent
格式化输出JSON字符串。
package mainimport ( "encoding/json" "fmt" "log")type Person struct { Name string `json:"name"` Age int `json:"age"`}func main() { jsonData := `{"name": "Bob", "age": 25}` var person Person err := json.Unmarshal([]byte(jsonData), &person) if err != nil { log.Fatal(err) } fmt.Printf("Person: %+vn", person) // 使用 MarshalIndent 格式化 JSON prettyJSON, err := json.MarshalIndent(person, "", " ") if err != nil { log.Fatal(err) } fmt.Println(string(prettyJSON))}
fmt库的格式化动词有哪些高级用法?
除了基本的格式化动词,
fmt
还支持一些高级用法,例如宽度和精度控制、flag的使用。
宽度控制可以用来对齐输出,精度控制可以用来控制浮点数的小数位数。Flag可以用来控制输出的符号、进制等。
package mainimport "fmt"func main() { num := 123.456 fmt.Printf("%10.2fn", num) // 宽度为10,保留2位小数 fmt.Printf("%+dn", 10) // 显示正号 fmt.Printf("%#xn", 255) // 输出0xff fmt.Printf("%05dn", 12) // 补零}
%10.2f
表示输出一个浮点数,总宽度为10个字符,保留2位小数。如果实际数字的宽度小于10,则会在左侧填充空格。
%+d
表示输出带正号的整数。
%#x
表示输出带
0x
前缀的十六进制数。
%05d
表示输出一个整数,总宽度为5个字符,如果实际数字的宽度小于5,则会在左侧填充0。
如何自定义fmt的输出格式?
可以通过实现
Stringer
接口来自定义类型的字符串表示形式。
Stringer
接口只有一个方法
String() string
。当使用
%s
或
%v
格式化输出实现了
Stringer
接口的类型时,
fmt
库会自动调用该类型的
String()
方法。
package mainimport "fmt"type Point struct { X, Y int}func (p Point) String() string { return fmt.Sprintf("(%d, %d)", p.X, p.Y)}func main() { point := Point{X: 10, Y: 20} fmt.Printf("Point: %sn", point) // 调用 Point 的 String() 方法 fmt.Printf("Point: %vn", point) // 调用 Point 的 String() 方法}
这个例子中,
Point
类型实现了
Stringer
接口,
String()
方法返回一个表示坐标的字符串。当使用
%s
或
%v
格式化输出
Point
类型时,
fmt
库会自动调用
String()
方法,输出自定义的字符串表示形式。这使得我们可以更灵活地控制类型的输出格式。
以上就是Golang fmt库格式化输出与使用技巧的详细内容,更多请关注创想鸟其它相关文章!
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1404916.html
微信扫一扫
支付宝扫一扫