魔杖无法打开现有文件

时间:2017-10-30 15:21:42

标签: python imagemagick travis-ci wand

我想打开pdf文件,只获取第一页并将其另存为图像。 我使用过this solution并且它完美无缺。它仍然适用于我的本地环境,但它最近无法在Travis中运行。

所以,是的,这段代码来自我的unittest,我正试图在Travis中运行它。 我有一个测试pdf文件,我想打开它:

import os
from wand.image import Image

root_path = 'some/correct/path'
filename = 'two_page_pdf.pdf'
full_path = os.path.join(root_parg, filename)
Image(file=open(full_path, mode='rb'), resolution=300) # Error!!!

-----------------------------------------------
DelegateError                             
Traceback (most recent call last)
<ipython-input-2-1b1fd9537a14> in <module>()
----> 1 Image(file=open(full_path, mode='rb'), resolution=300)

~/virtualenv/python3.5.3/lib/python3.5/site-packages/wand/image.py in __init__(self, image, blob, file, filename, format, width, height, depth, background, resolution)
   2738                                                   b'buffer.' + format)
   2739                 if file is not None:
-> 2740                     self.read(file=file, resolution=resolution)
   2741                 elif blob is not None:
   2742                     self.read(blob=blob, resolution=resolution)

~/virtualenv/python3.5.3/lib/python3.5/site-packages/wand/image.py in read(self, file, filename, blob, resolution)
   2820             r = library.MagickReadImage(self.wand, filename)
   2821         if not r:
-> 2822             self.raise_exception()
   2823 
   2824     def close(self):

~/virtualenv/python3.5.3/lib/python3.5/site-packages/wand/resource.py in raise_exception(self, stacklevel)
    220             warnings.warn(e, stacklevel=stacklevel + 1)
    221         elif isinstance(e, Exception):
--> 222             raise e
    223 
    224     def __enter__(self):

DelegateError: Postscript delegate failed `/tmp/magick-5ypXvY6l': No such file or directory @ error/pdf.c/ReadPDFImage/677

检查文件:

os.path.isfile(full_path) == True 
len(open(full_path, mode='rb').read()) == 18386

ENV:

  • python 3.5.3
  • Wand 0.4.4

有什么问题?我被卡住了。请帮忙

UPD 1:

Imagemagick包似乎参与了这个!上次测试在版本8:6.6.9.7-5ubuntu3.9时已过,并且在更新到8:6.7.7.10-6ubuntu3.9后停止工作

UPD 2:

.travis.yml档案。

language: python
sudo: false
cache: pip
python: "3.5"
services:
  - rabbitmq
addons:
  apt:
    packages:
    - imagemagick
    - python-enchant

1 个答案:

答案 0 :(得分:0)

此错误的原因是缺少PDF代理(ghostscript)。我刚将此应用添加到addons > apt > packages travis.yml部分