推荐使用 github.com/disintegration/imaging 库批量缩放图片,支持保持宽高比缩放(imaging.Thumbnail)、裁剪(imaging.Fill)、JPEG/WebP 格式转换及质量控制,并可通过 goroutine+channel 并发处理、CLI 参数化封装提升效率。

用Golang批量缩放图片:选对库,控制尺寸与质量
Go语言本身不内置图像处理能力,需依赖第三方库。推荐使用 github.com/disintegration/imaging —— 轻量、纯Go实现、无CGO依赖,适合服务端批量任务。缩放时注意保持宽高比,避免拉伸变形;可指定目标宽度或高度,让库自动计算另一维(用 imaging.Thumbnail 最稳妥)。
- 按宽度缩放并保持比例:
imaging.Thumbnail(src, 800, 0, imaging.Lanczos) - 强制裁剪为指定尺寸(居中取图):
imaging.Fill(src, 400, 300, imaging.Center, imaging.Lanczos) - 质量控制:JPEG保存时传入
imaging.JPEGQuality(85)参数,平衡体积与清晰度
批量转换图片格式:统一输入输出路径,避免覆盖原图
常见需求是把 PNG 批量转成 JPEG 或 WebP。imaging 支持读取 JPG/PNG/GIF/BMP,写入 JPG/PNG/WebP(WebP 需 Go 1.16+ 和启用 CGO)。关键点是分离输入输出目录,用文件扩展名判断源格式,再按需指定目标格式。
- 读取任意支持格式:
imaging.Open("input.png")自动识别 - 保存为 JPEG:
imaging.Save(img, "output.jpg", imaging.JPEGQuality(90)) - 保存为 WebP(需编译时开启 CGO):
imaging.Save(img, "output.webp", imaging.WebPQuality(80)) - 建议用
filepath.Base()和strings.ReplaceAll()安全替换后缀,例如strings.ReplaceAll(name, ".png", ".jpg")
并发处理提升效率:用 goroutine + channel 控制并发数
单协程处理几百张图会很慢。用带缓冲的 channel 限制并发数量(如 5–10),避免内存暴涨或系统负载过高。每张图开一个 goroutine 处理,结果通过 channel 收集或直接写入磁盘。
- 定义 worker 数量:
const workers = 8 - 用
make(chan string, 100)作为任务队列,发送文件路径 - 启动固定数量 goroutine 消费 channel,每个执行
processImage(filePath) - 错误处理别忽略:每个 worker 应捕获 panic 并记录日志,不影响其他任务
命令行工具封装:支持参数化操作,便于运维集成
用 github.com/spf13/cobra 或原生 flag 包做成 CLI 工具,常用参数包括:输入目录、输出目录、目标宽度、目标格式、质量值、是否递归遍历。这样运维可直接写 shell 脚本调度,也方便 CI/CD 中调用。
立即学习“go语言免费学习笔记(深入)”;
- 示例命令:
imgtool resize --in ./raw --out ./resized --width 1200 --format jpeg --quality 85 - 支持 glob 模式(如
**/*.png)需引入golang.org/x/exp/filepath或用filepath.WalkDir(Go 1.16+) - 进度提示可用
fmt.Printf("\rProcessed: %d/%d", done, total)实现简单行内刷新










