2013-04-17 6 views
8

私はキャンバスを使用してテーブルに表示するための画像のBase64インライン符号化データを作成したいと考えています。 PythonはWebページを動的に生成して作成します。それは、Pythonがイメージモジュールを使ってサムネイルを作成することを意味します。すべてのサムネイルが作成された後、Pythonは各サムネイルのbase64データを生成し、b64データをユーザのWebページの隠しスパンに配置します。次に、ユーザは、各サムネイルのチェックマークを、その興味に関連してクリックする。次に、[pdf生成]ボタンをクリックして、選択した画像を含むpdfファイルを作成します。 jsPDFを使用しているJavaScriptは、隠されたスパンb64データを生成して、pdfファイル、そして最終的にはpdfファイルに画像ファイルを作成します。Imageオブジェクトからencodeb64を作成することはできますか?

私は、スクリプトの実行中にPythonスクリプトの実行時間を短縮し、メモリ内のbase64サムネイルデータを生成することで、ディスクI/O操作を最小限に抑えることを望んでいます。

これは私が達成したいものの例です。

import os, sys 
import Image 
size = 128, 128 
    im = Image.open("/original/image/1.jpeg") 
    im.thumbnail(size) 
    thumb = base64.b64encode(im) 

これは悲しげに働く、TypeErorrを取得できません - これを実現する方法について

TypeError: must be string or buffer, not instance 

任意の考え?

答えて

11

あなたJPEG形式の画像を再度保存する最初の必要性。 im.tostring()メソッドを使用すると、そうでなければ、ブラウザが認識しないことを生の画像データを返します:

from io import BytesIO 
output = BytesIO() 
im.save(output, format='JPEG') 
im_data = output.getvalue() 

これ、あなたはその後、BASE64にエンコードすることができます:

:ここ

data_url = 'data:image/jpg;base64,' + base64.b64encode(im_data) 

が、私はこの方法で作られたものです

 

残念ながら、Markdownパーサーではこれを実際のイメージとして使用することはできませんが、代わりにスニペットで表示されます:

のPython 3では

<img src=""/>

+0

+1これはjpgへのエンコードを取得するのに良い方法です:) –

+0

両方の回答が私のやりたいことのために働いていますが、これは私のプログラムと一直線になっていて流体でした:)だから私はあなたと一緒に行きますこれ!私は両方から借りてくるので、私は答えとして両方を受け入れることができれば嬉しいですが、StringIOは私のために本当にうまくいくようです!みんな、ありがとう! – 0xhughes

+0

ああ、あまりにも長いbase64データで、ブラウザが1分遅れました。 – youngminz

3
thumb = base64.b64encode(im.tostring()) 

私は仕事だと思う

+0

(im.tostring 'として、動作しません。いや、)' *生*が返されます画像マトリックスであり、JPEG符号化データではない。 –

+0

ですが、 'Image.fromtext(b64decode(my_encoded_raw))'ではうまくいくはずですか?またはそれは嘘(私はそれを試していない)ですか? ... –

+0

私はうまくいくはずです、はい、しかしデータURLのためではありません。 :-) –

2

、あなたがBytesIOを使用する必要があります。

from io import BytesIO 

... 

outputBuffer = BytesIO() 
bg.save(outputBuffer, format='JPEG') 
bgBase64Data = outputBuffer.getvalue() 

# http://stackoverflow.com/q/16748083/2603230 
return 'data:image/jpeg;base64,' + base64.b64encode(bgBase64Data).decode() 
関連する問題