ImageMagick
是Linux上超强大、功能超丰富的图片处理的命令行工具。
而ImageMagick
在作PDF相关的工做时,是基于Ghostscript
进行处理的。因此两个都要安装。app
首先确保本机已经安装ImageMagick与Ghostscript, 工具
Mac安装:spa
brew install ghostscript imagemagick
Ubuntu安装:命令行
sudo apt-get install -y ghostscript imagemagick # on error: sudo apt-get update
安装好后,命令行里就能够调用ImageMagick的一系列命令了,包括:code
经常使用命令有:图片
#JPG图片转为PNG图片 $ convert image.jpg image.png #将图片缩放为50%大小 $ convert image.png -resize 50% image2.png #将图片缩放为指定长宽 $ convert image.png -resize 640x480 image2.png #横向合并图片 $ convert image1.png image2.png image3.png +append image123.png
用imagemagick
将pdf转成图片(不是提取图片)的命令是:ip
$ convert sample.pdf sample.jpg
命令很是简单,速度也极快。可是在PDF转图片的过程当中,若是不加任何设置直接convert xx.pdf xx.png
这样的转换,效果但是很是之差,以下图:图片处理
注意:通常若是设置输出为png的话,程序会提出警告:
convert: profile 'icc': 'RGB ': RGB color space not permitted on grayscale PNG sample-default-convert.png' @ warning/png.c/MagickPNGWarningHandler/1744.
这是由于程序没有很好支持PNG
格式图片的问题。虽然报错,可是png文件也能正常生成。若是不喜欢的话,就改为JPG
格式输出好了。rem
清晰度设置
convert
命令将PDF转图片的最大难度在于清晰度问题。网上有不少种解决方案,各有优缺。get
如下为一些尝试的总结:
# 默认转换:图片大小几乎与pdf相同 $ convert sample.pdf sample.jpg # resize设置:不管resize 100仍是3000,都没有清晰化 $ convert -resize 3000 sample.pdf sample.jpg # quality设置:彻底没有做用 $ convert -quality 100% sample.pdf sample.jpg # verbose+density+quality+flatten+sharpen转换:也就大概还原了80%的清晰度 $ convert -verbose -density 150 -trim -quality 100 -flatten -sharpen 0x1.0 sample.pdf sample.jpg # density 300转换:100%还原,可是文件增大10倍 $ convert -density 300 -trim -quality 100 sample.pdf sample.jpg # geometry 转换:100%还原,文件增大7倍 $ convert -geometry 1600x1600 -density 200x200 -quality 100 sample.pdf sample.jpg
总结:通过各类考察,中外网友对convert
转换图片的清晰度设置,也全都在猜的阶段。并且设置都太固定,并不能稳定保证全部的PDF都转换成同样的清晰度。
因此问题须要转换另外一个思路去解决:
直接提取PDF中的原画,这样就100%是原画质了。
并且通常对于扫描书籍的PDF来讲,全页只有一个图片,因此用pdfimages
就比较好解决。
这个须要另外一个命令行工具pdfimages
来作到了。
请参考另外一篇相关笔记。
cd /path/to/images/ convert "*.{png,jpeg,jpg}" -quality 100 outfile.pdf