Não é possível converter PDF em imagem, devido ao erro 'sem imagens definidas'

83

Eu tenho o seguinte arquivo PDF: http://www.fmwconcepts.com/misc_tests/pdf_tests/test.pdf

Mas quando estou tentando convertê-lo via:

$ convert test.pdf test.png

Eu tenho o seguinte erro:

convert: no images defined `test.png' @ error/convert.c/ConvertImageCommand/3187.

Eu tenho as seguintes versões:

$ brew info libpng
libpng: stable 1.6.13 (bottled)

$ brew info libjpeg
jpeg: stable 8d (bottled)

$ brew info imagemagick
imagemagick: stable 6.8.9-7 (bottled), HEAD
http://www.imagemagick.org
/usr/local/Cellar/imagemagick/6.8.9-1 (1432 files, 22M) *
  Poured from bottle
From: https://github.com/Homebrew/homebrew/blob/master/Library/Formula/imagemagick.rb
==> Dependencies
Build: xz ✔, pkg-config ✔
Required: libtool ✔
Recommended: jpeg ✔, libpng ✔, freetype ✔
Optional: fontconfig ✔, libtiff ✔, little-cms ✔, little-cms2 ✔, libwmf ✘, librsvg ✘, liblqr ✘, openexr ✘, ghostscript ✘, webp ✘

Eu tenho o seguinte log de depuração:

$ convert test.pdf test.png -debug all
2014-10-01T15:29:39+01:00 0:00.000 0.000u 6.8.9 Configure convert[58320]: utility.c/ExpandFilenames/944/Configure
  Command line: convert {test.pdf} {test.png} {-debug} {all}
2014-10-01T15:29:39+01:00 0:00.000 0.000u 6.8.9 Configure convert[58320]: configure.c/GetConfigureOptions/679/Configure
  Searching for configure file: "/usr/local/Cellar/imagemagick/6.8.9-1/share/ImageMagick-6/coder.xml"
...
2014-10-01T15:29:39+01:00 0:00.020 0.010u 6.8.9 Module convert[58320]: module.c/OpenModule/1268/Module
  Searching for module "PNG" using filename "png.la"
2014-10-01T15:29:39+01:00 0:00.020 0.010u 6.8.9 Module convert[58320]: module.c/GetMagickModulePath/554/Module
  Searching for coder module file "png.la" ...
2014-10-01T15:29:39+01:00 0:00.020 0.010u 6.8.9 Module convert[58320]: module.c/OpenModule/1277/Module
  Opening module at path "/usr/local/Cellar/imagemagick/6.8.9-1/lib/ImageMagick//modules-Q16/coders/png.la"
2014-10-01T15:29:39+01:00 0:00.020 0.010u 6.8.9 Module convert[58320]: module.c/OpenModule/1304/Module
  Method "RegisterPNGImage" in module "PNG" at address 0x10a9fdb60
2014-10-01T15:29:39+01:00 0:00.020 0.010u 6.8.9 Module convert[58320]: module.c/OpenModule/1318/Module
  Method "UnregisterPNGImage" in module "PNG" at address 0x10aa0785d
2014-10-01T15:29:39+01:00 0:00.020 0.010u 6.8.9 Policy convert[58320]: policy.c/IsRightsAuthorized/574/Policy
  Domain: Path; rights=Read; pattern="test.png" ...
...
2014-10-01T15:29:39+01:00 0:00.020 0.010u 6.8.9 Configure convert[58320]: locale.c/LoadLocaleCache/1186/Configure
  Loading locale configure file "/usr/local/Cellar/imagemagick/6.8.9-1/share/ImageMagick-6/english.xml" ...
2014-10-01T15:29:39+01:00 0:00.020 0.020u 6.8.9 Exception convert[58320]: blob.c/OpenBlob/2657/Exception
  unable to open image `test.png': No such file or directory
2014-10-01T15:29:39+01:00 0:00.020 0.020u 6.8.9 Cache convert[58320]: cache.c/DestroyPixelCache/962/Cache
  destroy 
2014-10-01T15:29:39+01:00 0:00.020 0.020u 6.8.9 Policy convert[58320]: policy.c/IsRightsAuthorized/574/Policy
  Domain: Coder; rights=Read; pattern="PNG" ...
2014-10-01T15:29:39+01:00 0:00.030 0.020u 6.8.9 Coder convert[58320]: png.c/ReadPNGImage/4015/Coder
  Enter ReadPNGImage()
2014-10-01T15:29:39+01:00 0:00.030 0.020u 6.8.9 Policy convert[58320]: policy.c/IsRightsAuthorized/574/Policy
  Domain: Path; rights=Read; pattern="test.png" ...
2014-10-01T15:29:39+01:00 0:00.030 0.020u 6.8.9 Exception convert[58320]: blob.c/OpenBlob/2657/Exception
  unable to open image `test.png': No such file or directory
2014-10-01T15:29:39+01:00 0:00.030 0.020u 6.8.9 Exception convert[58320]: png.c/ReadPNGImage/4021/Exception
  unable to open file `test.png'

Mas não mostra nada óbvio. E parece que esse log de depuração se comporta completamente diferente do que sem -debug, porque o erro original não está lá. Veja o log completo .

Existe um problema semelhante em http://www.imagemagick.org/discourse-server/viewtopic.php?f=3&t=22466 , mas não entendi bem qual é a solução.

kenorb
fonte

Respostas:

91

Está faltando a dependência opcional do Ghostscript gs- que não é opcional se você deseja converter um arquivo PDF.

Se which gsnão resolver o binário ghostscript (por exemplo, você tem um alias com o mesmo nome), edite o caminho para Ghostscript em delegates.xml.

dlemstra
fonte
11
No meu caso, eu tinha o Ghostscript instalado, mas o gscomando estava oculto por um script para o qual escrevi git status. Existe uma maneira de alimentar o ImageMagick com o caminho completo do gsbinário para que eu não precise remover meu script (ou apelido)?
precisa saber é o seguinte
2
Você precisará editar o arquivo delegates.xml e especificar o local alternativo.
precisa saber é o seguinte
debian / ubuntu: apt-get install ghostscript
Nadir /
69

Você também pode tentar:

  1. brew uninstall ghostscript
  2. brew install ghostscript

Isso consertou para mim.

hotmeteor
fonte
Isso fez o truque!
Line-o
-1

Eu tive um problema parecido. As correções acima não fizeram nada para mim, mas parece que o ImageMagick estava usando html2psinternamente.

Então, a solução foi instalar isso. Eu não estou no OS X, então para mim a solução foi:

apt install html2ps

Espero que isso ajude alguém.

mlissner
fonte
aptou apt-get?
kenorb
11
apt se você tiver. É a substituição do apt-get.
mlissner
ImageMagick estava usando html2ps internamente para converter de pdf para png aqui?
Rogerdpack #