Неможливо перетворити PDF у зображення через помилку "не визначено зображень"


83

У мене є такий PDF-файл: http://www.fmwconcepts.com/misc_tests/pdf_tests/test.pdf

Але коли я намагаюся конвертувати це за допомогою:

$ convert test.pdf test.png

У мене така помилка:

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

У мене такі версії:

$ 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 ✘

У мене є такий журнал налагодження:

$ 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'

Але нічого очевидного не показує. І здається, що цей журнал налагодження поводиться зовсім інакше, ніж без -debug, тому що оригінальної помилки немає. Дивіться повний журнал .

Існує аналогічне питання на веб- сайті http://www.imagemagick.org/discourse-server/viewtopic.php?f=3&t=22466 , але я не зовсім зрозумів, що таке рішення.

Відповіді:


91

Вам не вистачає додаткової залежності від Ghostscript gs- що необов'язково, якщо ви хочете конвертувати PDF-файл.

Якщо which gsце не вирішує бінарний файл ghostscript (наприклад, у вас псевдонім з тим самим іменем), відредагуйте шлях до Ghostscript у delegates.xml.


1
У моєму випадку у мене був встановлений Ghostscript, але gsкоманда була прихована сценарієм, для якого я писав git status. Чи є спосіб подати ImageMagick повний шлях gsбінарного файлу, щоб мені не довелося видаляти свій скрипт (або псевдонім)?
Шрідхар Сарнобат

2
Вам потрібно буде відредагувати файл deletes.xml та вказати альтернативне місце розташування.
длемстра

debian / ubuntu: apt-get install ghostscript
Nadir

69

Ви також можете спробувати зробити:

  1. brew uninstall ghostscript
  2. brew install ghostscript

Це зафіксувало це для мене.


Це зробив трюк!
лінія-о

-1

У мене була схожа проблема. Виправлені вище помилки для мене нічого не зробили, але схоже, що ImageMagick використовував html2psвсередині.

Отже, рішенням було встановити це. Я не в ОС X, тому для мене рішення було:

apt install html2ps

Сподіваємось, це комусь допоможе.


aptабо apt-get?
kenorb

1
підходить, якщо у вас є. Це заміна apt-get.
mlissner

ImageMagick використовував html2ps для перетворення з PDF у png тут?
rogerdpack
Використовуючи наш веб-сайт, ви визнаєте, що прочитали та зрозуміли наші Політику щодо файлів cookie та Політику конфіденційності.
Licensed under cc by-sa 3.0 with attribution required.