通八洲科技

如何使用Golang fmt格式化输出_Println、Printf和Sprintf示例

日期:2025-12-26 00:00 / 作者:P粉602998670
Go的fmt包三大输出函数区别在于输出目标和是否格式化:Println简单换行输出、不支持格式化;Printf格式化后输出到控制台;Sprintf格式化后返回字符串。

Go 的 fmt 包提供了三种最常用的输出函数:Println、Printf 和 Sprintf,它们用途不同,关键区别在于“输出到哪里”和“是否格式化”。

Println:简单换行输出,不支持格式化占位符

Println 用于快速打印变量值,自动在末尾加换行,并在多个参数间加空格。它不识别 %v、%s 等格式动词,传入格式字符串也不会被解析。

示例:

fmt.Println("Hello", 42, true)        // 输出:Hello 42 true
fmt.Println("Name: %s, Age: %d", "Alice", 30) // 输出:Name: %s, Age: %d Alice 30(%s 不会被替换)

✅ 适合调试时快速看值;❌ 不适合构造带格式的字符串。

Printf:格式化并直接输出到标准输出(控制台)

Printf 接收一个格式化字符串(含 % 开头的动词),再按顺序传入对应类型的参数,最终直接打印到终端,不自动换行。

常用动词:

示例:

name := "Bob"
age := 28
fmt.Printf("Name: %s, Age: %d\n", name, age) // 输出:Name: Bob, Age: 28
fmt.Printf("Value: %v\n", []int{1, 2, 3}) // 输出:Value: [1 2 3]
fmt.Printf("Quoted: %q\n", "hello\nworld") // 输出:Quoted: "hello\nworld"

Sprintf:格式化并返回字符串,不输出到屏幕

Sprintf 功能和 Printf 完全一致,但不打印,而是返回一个格式化后的 string,常用于拼接日志、生成文件名、构建 HTTP 请求体等场景。

示例:

title := "Golang fmt"
year := 2025
msg := fmt.Sprintf("Tutorial: %s (%d)", title, year)
fmt.Println(msg) // 输出:Tutorial: Golang fmt (2025)

// 也可直接赋值或传参:
logEntry := fmt.Sprintf("[INFO] %s started at %v", "server", time.Now())

小贴士:避免常见错误

掌握这三者的分工——Println 快速看值、Printf 控制台格式输出、Sprintf 构造字符串——就能清晰选择,写出更稳更可读的 Go 日志和提示逻辑。