Python 2.7、谷歌应用引擎、ndb.Model
我将 .jpg 图像存储为
signblobkey = ndb.BlobKeyProperty(verbose_name='Signature')
这些可以完美地存储和显示在 html 页面中。但是,我无法弄清楚如何使用 reportlab 在 .pdf 中“打印”这些。
我目前的代码是:
blobattach = ''
blobname = ''
blobmime = 'None'
if self.filetext.signblobkey != None:
blob_info = blobstore.BlobInfo.get(self.filetext.signblobkey)
blobmime = blob_info.content_type[:5]
blobname = blob_info.filename
if blobmime == 'image':
blobattach = get_serving_url(self.filetext.signblobkey)
canvas.ImageReader(StringIO.StringIO(self.filetext.signblobkey))
self.p.drawImage(image=blobattach,
x=self.colleft,
y=c_lineprint - (4 * self.lineheight),
width=self.colright - self.colleft,
height=4 * self.lineheight,
mask=None,
preserveAspectRatio=True,
anchor='nw')
我显然在这里遗漏了一些东西,我似乎没有访问实际图像。对我有什么线索吗?
谢谢,大卫
好吧,您作为image
to传递的self.p.drawImage
内容只是blobattach
,充其量只是一个 URL。您可能需要将图像传递给它。
您可以尝试将该 URL 传递给ImageReader
(它显然知道如何使用 URL)并将结果用作图像。您现在传递ImageReader
的不是 URL。我不太确定它是什么 - 我怀疑StringIO
(或ImageReader
就此而言)知道如何处理 blob 键(您的self.filetext.signblobkey
)。
或者您可以尝试直接从 blobstore 读取图像,从您的self.filetext.signblobkey
. 沿着这些路线的东西(您需要使用 blobstore API 来正确解释 blob 键):
with blobstore.BlobReader(self.filetext.signblobkey) as fd:
blob_content = fd.read()
不确定它究竟是如何工作的,但是,我还没有玩过图像(还)。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句