
本文介绍在 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("你输入的是: %q\n", 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 工具的基础能力。










