Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

How to save plotly express plot into a html or static image file?

However, I feel saving the figure with plotly.express is pretty tricky.

How to save plotly.express or plotly plot into a individual html or static image file? Anyone can help?

like image 631
roudan Avatar asked Jan 20 '20 00:01

roudan


4 Answers

Updated answer:

With newer versions of plotly, static Image export in Python is a breeze. Just make sure to install kaleido using:

pip install -U kaleido

or, for Anaconda:

conda install -c conda-forge python-kaleido

And then run

fig.write_image("yourfile.png") 

Filetypes such as .jpeg and .pdf are also available options.

Producing an individual html file is still very easy:

Just use plotly.offline.plot(fig, filename='C:/plotlyplots/canada_offline.html')

This will give you a html file of a plotly express bar chart with the name lifeExp in a desired folder. Remember import plotly and not only import plotly.express as px.

Complete code:

# imports
import plotly
import plotly.express as px

# data
df = px.data.gapminder().query("continent=='Oceania'")

# plotly express bar chart
fig = px.line(df, x="year", y="lifeExp", color='country')

# html file
plotly.offline.plot(fig, filename='C:/plotlyplots/lifeExp.html')

Plot:

enter image description here

File as it appears in the foler:

enter image description here

From here you can open the file in any browser or any other way you want.

Here's the content as it is displayed using Notepad++

enter image description here

If you don't mind a bit of manual labor, you dan save a .png version using the toolbar:

enter image description here


Old answer for static images:

Producing a static image automatically is a bit mote tricky.

Take a look at Static Image Export in Python if you prefer that to html.

I like to use the approach including orca that can produce a variety of image files. I haven't found any other way to install it other than using npm which is installed with node.js If you get that in order, you only have to go run the following to get it up and running (I'm on Windows):

npm install -g [email protected] orca

pip install psutil requests

Then you can change the last line in the snippet above with fig.write_image("C:/plotlyplots/lifeExp.png") to produce a .png file.

like image 129
vestland Avatar answered Oct 06 '22 01:10

vestland


Exporting a static image in Python

Short story: pip install kaleido, then fig.write_image(<output_filename>).

I stumbled on this as I am also looking for ways on how to export plotly figures to static images. I realized that installing orca and making it work is not so easy, but good thing is they actually made this package called kaleido that is easier to install. Found it from these links:

  • https://github.com/plotly/orca/issues/194
  • https://plotly.com/python/static-image-export/
like image 27
rjd Avatar answered Oct 06 '22 01:10

rjd


Somehow the above solution for .html files did not work, but I found that

from pathlib import Path

with Path("myfile.html").open("w") as f:
    f.write(fig.to_html())

worked just fine.

like image 20
TaZi Avatar answered Oct 06 '22 00:10

TaZi


Adding to @vestland 's answer about saving to HTML, another way to do it according to the documentation would be:

import plotly.express as px

# a sample scatter plot figure created
fig = px.scatter(x=range(10), y=range(10))
fig.write_html("path/to/file.html")

You can read about it further (controlling size of the HTML file) here: Interactive HTML Export in Python

like image 34
Aadi Shah Avatar answered Oct 05 '22 23:10

Aadi Shah