推荐使用 github.com/disintegration/imaging 库批量缩放图片,支持保持宽高比缩放(imaging.Thumbnail)、裁剪(imaging.Fill)、JPEG/WebP 格式转换及质量控制,并可通过 goroutine+channel 并发处理、CLI 参数化封装提升效率。
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)
imaging.JPEGQuality(85) 参数,平衡体积与清晰度常见需求是把 PNG 批量转成 JPEG 或 WebP。imaging 支持读取 JPG/PNG/GIF/BMP,写入 JPG/PNG/WebP(WebP 需 Go 1.16+ 和启用 CGO)。关键点是分离输入输出目录,用文件扩展名判断源格式,再按需指定目标格式。
imaging.Open("input.png") 自动识别imaging.Save(img, "output.jpg", imaging.JPEGQuality(90))
imaging.Save(img, "output.webp", imaging.WebPQuality(80))
filepath.Base() 和 strings.ReplaceAll() 安全替换后缀,例如 strings.ReplaceAll(name, ".png", ".jpg")
单协程处理几百张图会很慢。用带缓冲的 channel 限制并发数量(如 5–10),避免内存暴涨或系统负载过高。每张图开一个 goroutine 处理,结果通过 channel 收集或直接写入磁盘。
const workers = 8
make(chan string, 100) 作为任务队列,发送文件路径processImage(filePath)
用 github.com/spf13/cobra 或原生 flag 包做成 CLI 工具,常用参数包括:输入目录、输出目录、目标宽度、目标格式、质量值、是否递归遍历。这样运维可直接写 shell 脚本调度,也方便 CI/CD 中调用。
imgtool resize --in ./raw --out ./resized --width 1200 --format jpeg --quality 85
**/*.png)需引入 golang.org/x/exp/filepath 或用 filepath.WalkDir(Go 1.16+)
用 fmt.Printf("\rProcessed: %d/%d", done, total) 实现简单行内刷新