Printf直接输出到标准输出,Sprintf返回格式化字符串;动词如%s、%d需与参数数量严格匹配,%+v适合结构体调试,Fprintf和Errorf分别用于自定义写入和错误包装。
Go 语言中 fmt 包的 Printf 和 Sprintf 是最常用的格式化输出工具,核心在于理解动词(verbs)和参数顺序,而非复杂语法。
Printf 将格式化后的字符串打印到终端(os.Stdout),适合调试或用户可见的日志。
fmt.Printf("姓名:%s,年龄:%d\n", "张三", 25) → 输出:姓名:张三,年龄:25
%s(字符串)、%d(十进制整数)、%f(浮点数)、%v(默认值格式,适用于任意类型)、%+v(结构体字段名+值)
\n 不会自动添加,需手动写;否则输出会连在一起Sprintf 返回格式化后的字符串,不输出到屏幕,适合拼接、日志记录或传给其他函数。
msg := fmt.Sprintf("订单ID:%d,金额:%.2f元", 1001, 99.5) → msg 的值为 "订单ID:1001,金额:99.50元"
%.2f 表示保留两位小数,这是控制精度的常见方式fmt.Sprint(x) 或 fmt.Sprintln(x)(带换行)格式动词数量必须与参数数量严格匹配,否则运行时报 panic。
fmt.Printf("你好,%s", "李四", 30) → 多传了参数,会报错%+v,比如 fmt.Printf("%+v", user) 可清晰看到字段名和值%#v 输出 Go 语法风格的值(如带类型、引号等),便于排查数据结构如果要写入文件或自定义 io.Writer,用 fmt.Fprintf(w, "...", args...);若构建错误信息,fmt.Errorf 更合适(返回 error 类型,支持嵌套)。
fmt.Errorf("处理失败:%w", err) 是 Go 1.13+ 推荐的错误包装方式Fprintf(file, "日志:%s\n", msg) 把内容写入文件而非屏幕