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 main
import "fmt"
func main() {
name := "Alice"
age := 30
pi := 3.14159
fmt.Printf("Name: %s, Age: %d, Pi: %f\n", name, age, pi) // 基本用法
fmt.Printf("Pi with 2 decimals: %.2f\n", pi) // 精度控制
fmt.Printf("Age in binary: %b\n", age) // 二进制
fmt.Printf("Type of pi: %T\n", pi) // 类型
fmt.Printf("Value of pi: %v\n", pi) // 值
fmt.Printf("Default format for struct: %v\n", struct{ X, Y int }{10, 20})
fmt.Printf("Detailed format for struct: %+v\n", struct{ X, Y int }{10, 20})
fmt.Printf("Go syntax format for struct: %#v\n", 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字符串。
启科网络商城系统由启科网络技术开发团队完全自主开发,使用国内最流行高效的PHP程序语言,并用小巧的MySql作为数据库服务器,并且使用Smarty引擎来分离网站程序与前端设计代码,让建立的网站可以自由制作个性化的页面。 系统使用标签作为数据调用格式,网站前台开发人员只要简单学习系统标签功能和使用方法,将标签设置在制作的HTML模板中进行对网站数据、内容、信息等的调用,即可建设出美观、个性的网站。
package main
import (
"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: %+v\n", person)
// 使用 MarshalIndent 格式化 JSON
prettyJSON, err := json.MarshalIndent(person, "", " ")
if err != nil {
log.Fatal(err)
}
fmt.Println(string(prettyJSON))
}fmt库的格式化动词有哪些高级用法?
除了基本的格式化动词,
fmt还支持一些高级用法,例如宽度和精度控制、flag的使用。
宽度控制可以用来对齐输出,精度控制可以用来控制浮点数的小数位数。Flag可以用来控制输出的符号、进制等。
package main
import "fmt"
func main() {
num := 123.456
fmt.Printf("%10.2f\n", num) // 宽度为10,保留2位小数
fmt.Printf("%+d\n", 10) // 显示正号
fmt.Printf("%#x\n", 255) // 输出0xff
fmt.Printf("%05d\n", 12) // 补零
}%10.2f表示输出一个浮点数,总宽度为10个字符,保留2位小数。如果实际数字的宽度小于10,则会在左侧填充空格。
%+d表示输出带正号的整数。
%#x表示输出带
0x前缀的十六进制数。
%05d表示输出一个整数,总宽度为5个字符,如果实际数字的宽度小于5,则会在左侧填充0。
如何自定义fmt的输出格式?
可以通过实现
Stringer接口来自定义类型的字符串表示形式。
Stringer接口只有一个方法
String() string。当使用
%s或
%v格式化输出实现了
Stringer接口的类型时,
fmt库会自动调用该类型的
String()方法。
package main
import "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: %s\n", point) // 调用 Point 的 String() 方法
fmt.Printf("Point: %v\n", point) // 调用 Point 的 String() 方法
}这个例子中,
Point类型实现了
Stringer接口,
String()方法返回一个表示坐标的字符串。当使用
%s或
%v格式化输出
Point类型时,
fmt库会自动调用
String()方法,输出自定义的字符串表示形式。这使得我们可以更灵活地控制类型的输出格式。









