Skip to content

Instantly share code, notes, and snippets.

@rduplain
Created January 19, 2012 17:28
Show Gist options
  • Star 54 You must be signed in to star a gist
  • Fork 9 You must be signed in to fork a gist
  • Save rduplain/1641344 to your computer and use it in GitHub Desktop.
Save rduplain/1641344 to your computer and use it in GitHub Desktop.
Plot a PNG using matplotlib in a web request, using Flask.
"Plot a PNG using matplotlib in a web request, using Flask."
# Install dependencies, preferably in a virtualenv:
#
# pip install flask matplotlib
#
# Run the development server:
#
# python app.py
#
# Go to http://localhost:5000/plot.png and see a plot of random data.
import random
import StringIO
from flask import Flask, make_response
from matplotlib.backends.backend_agg import FigureCanvasAgg as FigureCanvas
from matplotlib.figure import Figure
app = Flask(__name__)
@app.route('/plot.png')
def plot():
fig = Figure()
axis = fig.add_subplot(1, 1, 1)
xs = range(100)
ys = [random.randint(1, 50) for x in xs]
axis.plot(xs, ys)
canvas = FigureCanvas(fig)
output = StringIO.StringIO()
canvas.print_png(output)
response = make_response(output.getvalue())
response.mimetype = 'image/png'
return response
if __name__ == '__main__':
app.run(debug=True)
@sburns
Copy link

sburns commented Apr 3, 2014

exactly what I needed, thank you.

@codefever
Copy link

i like it, thx!!!

@llazzaro
Copy link

thanks!

@mapfumo
Copy link

mapfumo commented Sep 6, 2015

Awesome. Thank you.

@smargs
Copy link

smargs commented Oct 29, 2015

Hi, thank you for the code. I ran it and got this msg '* Restarting with stat'. So i installed watchdog suggested in this post http://stackoverflow.com/questions/28241989/flask-app-restarting-with-stat and now I get this '* '*Restarting with windowsapi reloader'. And the localhost page doesn't work (keeps loading). Would you know how to make this work ? Thank you.

@anthonycarminati
Copy link

Is there a way to embed this into a flask template? Right now i'm passing the response variable into an html template using the render_template function, but the image is not showing up; instead, only the response string is rendering. Thank you in advance!

@kwanwasutumkethom
Copy link

thank you for alternative way to show plotted graph !

@mariacamilarg
Copy link

Thanks a lot! This was super useful :)

@saurabhsingh13no
Copy link

I am using python3.5 and ran the code with slight modification:

  1. Instead of import StringIO, I used import io
  2. Instead of output = StringIO.StringIO(), I used output = io.BytesIO()

Thanks

@YannickLeRoux
Copy link

Great help, thanks

@ruhinshaikh
Copy link

How to embed this response in the html page?

@nickkimer
Copy link

is there a way to embed this response into html template? I have been searching everywhere but have not been able to find a workaround

@zashishz
Copy link

You saved my life :). Very helpful!

@YummyELine
Copy link

YummyELine commented Jul 23, 2018

ran the code with slight modification

from flask import send_file
@route("/reports/")
def reports():
    return render_template('report.html')

@app.route('/fig/')
def fig():
  fig = plt.figure()
......
.....
.....
  img = io.BytesIO()
  fig.savefig(img)
  img.seek(0)
  return send_file(img, mimetype='image/png')

report HTML:
<img src="{{ url_for('fig') }}" alt="Image Placeholder">

@j-nila
Copy link

j-nila commented Mar 15, 2021

I am using python3.5 and ran the code with slight modification:

  1. Instead of import StringIO, I used import io
  2. Instead of output = StringIO.StringIO(), I used output = io.BytesIO()

Thanks

Very helpful, thanks!

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment