fmt包是go语言中用于格式化输入输出的核心工具,提供print系列函数实现打印功能,其中fmt.print不换行、fmt.println自动换行、fmt.printf支持格式化输出;通过%v、%d、%s等动词可控制数据展示形式,结合scan系列函数实现基本输入,配合bufio.scanner可高效处理含空格的完整输入,满足命令行交互需求。

在Go语言中,fmt 包是实现输入输出操作的核心工具。它提供了格式化输入和输出的函数,使用起来简单高效,适用于控制台交互、调试信息打印以及数据展示等场景。
fmt包常用输出函数
fmt.Print 系列函数用于将数据输出到标准输出(通常是终端)。它们之间的区别在于格式化方式和是否换行:
- fmt.Print:直接输出内容,不自动换行,多个参数间添加空格分隔
- fmt.Println:输出后自动换行,参数之间也用空格连接
- fmt.Printf:支持格式化字符串,可以精确控制输出格式,如整数、浮点数、字符串等
示例代码:
package main
import "fmt"
func main() {
name := "Alice"
age := 25
fmt.Print("Hello ", name, "! ")
fmt.Print("Age: ", age, "\n")
fmt.Println("Hello,", name, "you are", age, "years old.")
fmt.Printf("Name: %s, Age: %d\n", name, age)
}
fmt包常用输入函数
fmt.Scan 系列函数用于从标准输入读取数据,适合简单的命令行交互:
立即学习“go语言免费学习笔记(深入)”;
- fmt.Scan:读取空白符分隔的值,按顺序填充变量,遇到换行可能影响后续输入
- fmt.Scanf:支持格式化读取,类似 Printf 的逆过程
- fmt.Scanln:只读取一行中的内容,遇到换行停止
使用示例:
package main
import "fmt"
func main() {
var name string
var age int
fmt.Print("Enter your name and age: ")
fmt.Scan(&name, &age)
fmt.Printf("Hello %s, you are %d years old.\n", name, age)
}
注意:Scan 在处理包含空格的字符串时会截断,建议对完整句子使用 bufio.Scanner 配合 os.Stdin。
格式化动词详解
fmt 中的格式化字符串使用“动词”来指定类型输出方式:
- %v:默认格式输出任意值,最常用
- %+v:输出结构体时显示字段名
- %T:输出值的类型
- %d:十进制整数
- %f:浮点数
- %s:字符串
- %t:布尔值
- %p:指针地址
例子:
type Person struct {
Name string
Age int
}
p := Person{"Bob", 30}
fmt.Printf("%v\n", p) // {Bob 30}
fmt.Printf("%+v\n", p) // {Name:Bob Age:30}
fmt.Printf("%T\n", p) // main.Person
结合 bufio 提升输入体验
对于需要读取整行或处理复杂输入的情况,推荐使用 bufio.Scanner:
package main
import (
"bufio"
"fmt"
"os"
)
func main() {
scanner := bufio.NewScanner(os.Stdin)
fmt.Print("Enter a line: ")
if scanner.Scan() {
text := scanner.Text()
fmt.Printf("You entered: %s\n", text)
}
}
这种方式能正确读取包含空格的内容,更适合用户输入句子或路径等场景。
基本上就这些。fmt 包覆盖了大多数基础输入输出需求,配合 bufio 可以应对更复杂的交互逻辑。掌握这些方法后,Go 的命令行程序开发会变得非常顺畅。










