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