0

我正在使用 python 的 elaphe 包来生成 ean-13 条形码图像。该软件包是使用位于https://pypi.python.org/pypi/elaphe的 tar 文件从源代码安装的。

当我运行代码时:

BARCODE_IMAGE_PATH = "/tmp/"

def create_barcode_image(product_barcode):

    path = BARCODE_IMAGE_PATH + product_barcode + '.png'

    img = barcode('ean13', product_barcode, 
                  options=dict(includetext=True, height=0.4), margin=1)
    img.save(path, 'PNG')

    return path 

从 python 解释器看来,它似乎工作得很好。正确的条形码生成到我指定的路径。当我使用 web.py 作为我的 web 框架从 apache 运行它时,我收到错误:

Traceback (most recent call last):
  ...
     img_path = create_barcode_image(barcode)
   File "/var/www/py/documents/barcode_images.py", line 27, in create_barcode_image
     img.save(path, 'PNG')
   File "/usr/local/lib/python2.7/dist-packages/PIL/Image.py", line 1406, in save
     self.load()
   File "/usr/local/lib/python2.7/dist-packages/PIL/EpsImagePlugin.py", line 283, in load
     self.im = Ghostscript(self.tile, self.size, self.fp)
   File "/usr/local/lib/python2.7/dist-packages/PIL/EpsImagePlugin.py", line 75, in Ghostscript
     raise IOError("gs failed (status %d)" % status)
 IOError: gs failed (status 256) 

有谁知道可能导致此错误的原因或如何调试它?

4

3 回答 3

1

添加一些您可以通过的调试语句:

import sys

BARCODE_IMAGE_PATH = "/tmp/"

def create_barcode_image(product_barcode):

    print >> sys.stderr, "product_barcode: %s" % product_barcode

    path = BARCODE_IMAGE_PATH + product_barcode + '.png'

    print >> sys.stderr, "path: %s" % path

    img = barcode('ean13', product_barcode, 
                  options=dict(includetext=True, height=0.4), margin=1)

    print >> sys.stderr, "img data: %s" % img.tostring()

    img.save(path, 'PNG')

    print >> sys.stderr, "Saved to %s" % path

    return path 

然后在你的外壳中:

$ tail -F /var/log/httpd/error.log # or wherever you put it

您正在寻找:第一:“ product_barcode: ...”的输出。希望这不是空白。如果是,那么问题出在其他地方,可能在您的服务器配置中。然后是“ img data: ...”的输出。希望它是一个png而不是空白。如果它是空白的,那么问题出在您的 ghostscript 安装上。

这是一种非常初级的调试方式,我觉得对于小型项目来说,加入一些调试语句同样容易,而不是使用调试器,因为调试器很难正确设置。

于 2013-09-24T17:11:40.757 回答
1

堆栈跟踪表明返回的图像barcode()是 PostScript。PIL 然后尝试运行 GhostScript( gs) 将图像转换为所需的输出格式PNG

如果您查看elaphe 的描述,您会看到它说:

它使用 BWIPP 生成条形码符号作为 PostScript 代码片段。

你有安装 GhostScript 吗?

也就是说,我建议您改用pyBarcode,因为它除了 PIL 之外没有任何依赖项。

于 2013-09-25T07:31:45.510 回答
-1

barcode如果无效,可能会导致此错误。您应该首先确保它是您所期望的。例如。将其打印出来,或将其写入文件或使用调试器

于 2013-09-24T16:02:59.243 回答