ImageMagick 強大的PDF工具集

ImageMagick是Linux上超強大、功能超豐富的圖片處理的命令行工具。
ImageMagick在做PDF相關的工作時,是基於Ghostscript進行處理的。所以兩個都要安裝。

首先確保本機已經安裝ImageMagick與Ghostscript,

Mac安裝:

brew install ghostscript imagemagick

Ubuntu安裝:

sudo apt-get install -y ghostscript imagemagick

# on error: sudo apt-get update

安裝好後,命令行裏就可以調用ImageMagick的一系列命令了,包括:

  • convert

常用命令有:

#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

PDF轉圖片

imagemagick將pdf轉成圖片(不是提取圖片)的命令是:

$ convert sample.pdf sample.jpg

命令非常簡單,速度也極快。但是在PDF轉圖片的過程中,如果不加任何設置直接convert xx.pdf xx.png這樣的轉換,效果可是非常之差,如下圖:

image

注意:一般如果設置輸出爲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格式輸出好了。

清晰度設置

convert命令將PDF轉圖片的最大難度在於清晰度問題。網上有很多種解決方案,各有優缺。

以下爲一些嘗試的總結:

# 默認轉換:圖片大小几乎與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來做到了。
請參考另一篇相關筆記。

批量圖片合併爲PDF

cd /path/to/images/
convert "*.{png,jpeg,jpg}" -quality 100 outfile.pdf
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章