如何使用Golang实现图片压缩工具_批量处理图片并生成缩略图

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 自动处理)

示例函数:

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,例如:

compress -src ./photos -dst ./thumbs -max 300 -q 80 -ext jpg

支持参数:

  • -src:源目录(必填)
  • -dst:输出目录(自动创建)
  • -max:缩略图最大边长(默认 200)
  • -q:JPEG 质量(1–100,默认 80)
  • -ext:只处理指定扩展名(如 jpg,png

错误时打印具体文件名和原因,不中断整个流程。