Go图片压缩工具采用disintegration/imaging库,支持JPEG/PNG/WebP,通过Thumbnail自动缩放裁切,用channel+worker并发控制,配合flag实现CLI参数配置。

用 Go 语言写一个轻量、高效、可批量处理图片并生成缩略图的压缩工具,核心在于选对图像处理库、合理控制质量与尺寸、并支持并发安全地读写文件。下面直接给出实用方案,不绕弯。
选择合适的图像处理库
Go 生态中主流且稳定的选择是 golang.org/x/image(官方维护)搭配 github.com/disintegration/imaging(更易用、支持常用格式和滤镜)。后者封装了缩放、裁剪、质量控制等逻辑,对 JPEG/PNG/WebP 支持良好,且无 C 依赖。
安装命令:
go get github.com/disintegration/imaging定义压缩与缩略图逻辑
关键不是“把图变小”,而是按需控制:
– 压缩:降低 JPEG 质量(70–85)、去除元数据、保持原始宽高比
– 缩略图:指定最大边长(如 300px),等比缩放后居中裁切或填充(推荐 imaging.Thumbnail 自动处理)
立即学习“go语言免费学习笔记(深入)”;
示例函数:
func resizeAndSave(srcPath, dstPath string, maxWidth, maxHeight int, quality int) error {img, err := imaging.Open(srcPath)
if err != nil { return err }
thumb := imaging.Thumbnail(img, maxWidth, maxHeight, imaging.Lanczos)
return imaging.Save(thumb, dstPath, imaging.JPEGQuality(quality))
}
批量处理 + 并发控制
避免一次性加载所有图片到内存,用通道+Worker 模式逐个处理,限制 goroutine 数量防 OOM 或 I/O 打满:
- 用
filepath.WalkDir遍历目录,过滤 .jpg/.png/.webp - 创建带缓冲的 job channel,每个 job 是输入路径 + 输出路径 + 参数
- 启动固定数量(如 4)worker,从 channel 拿任务执行
resizeAndSave - 主 goroutine 负责发送任务、等待完成、统计失败数
命令行交互与配置支持
用标准库 flag 实现简单 CLI,例如:
支持参数:
-
-src:源目录(必填) -
-dst:输出目录(自动创建) -
-max:缩略图最大边长(默认 200) -
-q:JPEG 质量(1–100,默认 80) -
-ext:只处理指定扩展名(如jpg,png)
错误时打印具体文件名和原因,不中断整个流程。










