
本文介绍在 go 语言中正确读取含空格的用户输入的方法,重点讲解使用 `bufio.newreader(os.stdin)` 替代 `fmt.scanf` 的实践方案,并提供完整示例与注意事项。
在 Go 中,fmt.Scanf(“%s”, &input) 默认以空白字符(空格、制表符、换行符)为分隔符,因此只能读取第一个单词,无法获取整行含空格的输入(如 “Hello World” 会被截断为 “Hello”)。这是初学者常见的困惑点。
要完整读取一行(包括中间空格),推荐使用 bufio.NewReader 配合 ReadString(‘n’):
package main import ("bufio" "fmt" "os" "strings") func main() { fmt.Print("请输入一行文本(支持空格):") reader := bufio.NewReader(os.Stdin) line, err := reader.ReadString('n') if err != nil {fmt.Println("读取输入时出错:", err) return } // ReadString 会保留末尾的 'n',通常需去除 line = strings.TrimSpace(line) // 或用 strings.TrimSuffix(line, "n") fmt.Printf("你输入的是: %qn", line) }
✅ 关键说明:
- reader.ReadString(‘n’) 会一直读取直到遇到换行符(即用户按 Enter),返回包含换行符的字符串;
- 建议使用 strings.TrimSpace(line) 清除首尾空白(含 n, r, 空格等),更健壮;
- 若需多次读取,bufio.Reader 可复用,性能优于反复调用 fmt.Scanln 或 fmt.Scanf;
- ❌ 避免使用 fmt.Scanln() —— 它虽读取整行,但会因末尾换行符或类型不匹配导致意外截断或错误。
? 进阶提示:
如需读取不含换行符的原始 字节 流(例如处理二进制输入),可改用 io.ReadFull 或 reader.ReadBytes(‘n’);若需解析结构化输入(如多个字段用空格分隔但仍需保留各字段内空格),建议先整行读取,再用 strings.FieldsFunc 自定义分隔逻辑。
掌握这一模式,是编写交互式 Go CLI 工具 的基础能力。






























