Can I create a base64 encoded URL from an Image object?

I am looking to create embedded base64 encoded image data for display in a table using canvases. Python generates and creates a web page dynamically. Because this means that python uses the Image module to create thumbnails. After creating all the thumbnails, Python then generates the base64 data of each thumbnail and puts the b64 data in hidden gaps on the user's web page. The user then clicks the marks on each thumbnail regarding their interest. Then they create a PDF file containing the selected images by clicking the pdf generation button. JavaScript using jsPDF generates hidden data in the b64 range to create image files in a pdf file, and then, ultimately, in a pdf file.

I hope that we can reduce the execution time of the Python script and minimize some disk I / O by generating base64 sketch data in memory when the script is executed.

Here is an example of what I would like to accomplish.

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

This does not work sadly, get TypeErorr -

 TypeError: must be string or buffer, not instance 

Any thoughts on how to do this?

+11
python base64 python-imaging-library
source share
3 answers

First you need to save the image in JPEG format again; using the im.tostring() method otherwise will return raw image data that no browser will recognize:

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

This you can then encode in base64:

 image_data = base64.b64encode(im_data) if not isinstance(image_data, str): # Python 3, decode from bytes to string image_data = image_data.decode() data_url = 'data:image/jpg;base64,' + image_data 

Here is what I did with this method:

  

Unfortunately, the Markdown analyzer does not allow me to use this as an actual image, but instead you can see it in action:

 <img src=""/> 

+20
source share
  thumb = base64.b64encode(im.tostring()) 

I think it will work

+3
source share

In Python 3, you might need 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() 
+3
source share

All Articles