Skip to main content

Convert Vega-Lite chart specifications to SVG, PNG, or Vega

Project description

Overview

vl-convert-python is a dependency-free Python package for converting Vega-Lite chart specifications into static images (SVG or PNG) or Vega chart specifications.

Since an Altair chart can generate Vega-Lite, this package can be used to easily create static images from Altair charts.

Try it out on Binder!
Binder

Installation

vl-convert-python can be installed using pip with

$ pip install vl-convert-python

Usage

The vl-convert-python package provides a series of conversion functions under the vl_convert module.

Convert Vega-Lite to SVG, PNG, and Vega

The vegalite_to_svg and vegalite_to_png functions can be used to convert Vega-Lite specifications to static SVG and PNG images respectively. The vegalite_to_vega function can be used to convert a Vega-Lite specification to a Vega specification.

import vl_convert as vlc
import json

vl_spec = r"""
{
  "$schema": "https://vega.github.io/schema/vega-lite/v5.json",
  "data": {"url": "https://raw.githubusercontent.com/vega/vega-datasets/next/data/movies.json"},
  "mark": "circle",
  "encoding": {
    "x": {
      "bin": {"maxbins": 10},
      "field": "IMDB Rating"
    },
    "y": {
      "bin": {"maxbins": 10},
      "field": "Rotten Tomatoes Rating"
    },
    "size": {"aggregate": "count"}
  }
}
"""

# Create SVG image string and then write to a file
svg_str = vlc.vegalite_to_svg(vl_spec=vl_spec)
with open("chart.svg", "wt") as f:
    f.write(svg_str)

# Create PNG image data and then write to a file
png_data = vlc.vegalite_to_png(vl_spec=vl_spec, scale=2)
with open("chart.png", "wb") as f:
    f.write(png_data)

# Create low-level Vega representation of chart and write to file
vg_spec = vlc.vegalite_to_vega(vl_spec)
with open("chart.vg.json", "wt") as f:
    json.dump(vg_spec, f)

Convert Altair Chart to SVG, PNG, and Vega

The Altair visualization library provides a Pythonic API for generating Vega-Lite visualizations. As such, vl-convert-python can be used to convert Altair charts to PNG, SVG, or Vega. The vegalite_* functions support an optional vl_version argument that can be used to specify the particular version of the Vega-Lite JavaScript library to use. Version 4.2 of the Altair package uses Vega-Lite version 4.17, so this is the version that should be specified when converting Altair charts.

import altair as alt
from vega_datasets import data
import vl_convert as vlc
import json

source = data.barley()

chart = alt.Chart(source).mark_bar().encode(
    x='sum(yield)',
    y='variety',
    color='site'
)

# Create SVG image string and then write to a file
svg_str = vlc.vegalite_to_svg(chart.to_json(), vl_version="4.17")
with open("altair_chart.svg", "wt") as f:
    f.write(svg_str)

# Create PNG image data and then write to a file
png_data = vlc.vegalite_to_png(chart.to_json(), vl_version="4.17", scale=2)
with open("altair_chart.png", "wb") as f:
    f.write(png_data)

# Create low-level Vega representation of chart and write to file
vg_spec = vlc.vegalite_to_vega(chart.to_json(), vl_version="4.17")
with open("altair_chart.vg.json", "wt") as f:
    json.dump(vg_spec, f)

How it works

This crate uses PyO3 to wrap the vl-convert-rs Rust crate as a Python library. The vl-convert-rs crate is a self-contained Rust library for converting Vega-Lite visualization specifications into various formats. The conversions are performed using the Vega-Lite and Vega JavaScript libraries running in a v8 JavaScript runtime provided by the deno_runtime crate. Font metrics and SVG-to-PNG conversions are provided by the resvg crate.

Of note, vl-convert-python is fully self-contained and has no dependency on an external web browser or Node.js runtime.

Development setup

Create development conda environment

$ conda create -n vl-convert-dev -c conda-forge python=3.10 deno maturin altair pytest black black-jupyter scikit-image

Activate environment and pip install remaining dependencies

$ conda activate vl-convert-dev
$ pip install pypdfium2

Change to Python package directory

$ cd vl-convert-python

Build Rust python package with maturin in develop mode

$ maturin develop --release

Run tests

$ pytest tests

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

vl_convert_python-1.0.1rc1.tar.gz (3.9 MB view details)

Uploaded Source

Built Distributions

vl_convert_python-1.0.1rc1-cp37-abi3-win_amd64.whl (27.0 MB view details)

Uploaded CPython 3.7+ Windows x86-64

vl_convert_python-1.0.1rc1-cp37-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl (27.0 MB view details)

Uploaded CPython 3.7+ manylinux: glibc 2.17+ x86-64

vl_convert_python-1.0.1rc1-cp37-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl (26.2 MB view details)

Uploaded CPython 3.7+ manylinux: glibc 2.17+ ARM64

vl_convert_python-1.0.1rc1-cp37-abi3-macosx_11_0_arm64.whl (24.7 MB view details)

Uploaded CPython 3.7+ macOS 11.0+ ARM64

vl_convert_python-1.0.1rc1-cp37-abi3-macosx_10_7_x86_64.whl (25.9 MB view details)

Uploaded CPython 3.7+ macOS 10.7+ x86-64

File details

Details for the file vl_convert_python-1.0.1rc1.tar.gz.

File metadata

File hashes

Hashes for vl_convert_python-1.0.1rc1.tar.gz
Algorithm Hash digest
SHA256 824ac71cffa31718c7cad8f307359d1fdce6d215ef3e71f16b57acab6f98cf02
MD5 3d517c2fd4e3d6ed87e860261a3b407a
BLAKE2b-256 fd5bcf0e29fbc3ba728139757d13250700624a2d9cb4dabb7fb741a9f90ecba9

See more details on using hashes here.

File details

Details for the file vl_convert_python-1.0.1rc1-cp37-abi3-win_amd64.whl.

File metadata

File hashes

Hashes for vl_convert_python-1.0.1rc1-cp37-abi3-win_amd64.whl
Algorithm Hash digest
SHA256 c4c41fbd80afd87d4b5a430c84c86ebe211279b58ff272158e5895531d8131fd
MD5 5328c9ab1dedc631f5e18612795c99fb
BLAKE2b-256 4bff19fd903b38ea1fe11c65ff947d7f1e1fd4fc04aa38a02f643563ac95f1f5

See more details on using hashes here.

File details

Details for the file vl_convert_python-1.0.1rc1-cp37-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl.

File metadata

File hashes

Hashes for vl_convert_python-1.0.1rc1-cp37-abi3-manylinux_2_17_x86_64.manylinux2014_x86_64.whl
Algorithm Hash digest
SHA256 b860c00be9a3ce40097fd2216180fc0a1e6493c9521f7ebcba446dd77eb60de6
MD5 9f0e1d9cd937001291df5ece1c144d03
BLAKE2b-256 bd6fa3b82755af818105713992a5a4de5eddecd7e60f4e82d29eb47b19e9f300

See more details on using hashes here.

File details

Details for the file vl_convert_python-1.0.1rc1-cp37-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl.

File metadata

File hashes

Hashes for vl_convert_python-1.0.1rc1-cp37-abi3-manylinux_2_17_aarch64.manylinux2014_aarch64.whl
Algorithm Hash digest
SHA256 7196f94a36fb367cf960ca32e27272349f6131e31e96af0e4e32eb2a77914ea7
MD5 6c4726efbc9ebd7a79d6bcb1fa2d9e41
BLAKE2b-256 bf499b31c9c4165d2b320a2356c04f99b897af995cd6dbd388f015d78e9432a0

See more details on using hashes here.

File details

Details for the file vl_convert_python-1.0.1rc1-cp37-abi3-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for vl_convert_python-1.0.1rc1-cp37-abi3-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 1a699107b2cc9f85c8fe361250618fe34b6ed064ef9ad4df5cddec40bbe8dbea
MD5 22a07ae7908ca33f7039c6442a494250
BLAKE2b-256 99ab8d429ad07403def556016c6223b7e7cf3dff9b77089cdd7f5adf6b2cf73f

See more details on using hashes here.

File details

Details for the file vl_convert_python-1.0.1rc1-cp37-abi3-macosx_10_7_x86_64.whl.

File metadata

File hashes

Hashes for vl_convert_python-1.0.1rc1-cp37-abi3-macosx_10_7_x86_64.whl
Algorithm Hash digest
SHA256 6b9266fe7300f189c06cdc93d95080edabb1eaaa48c58c1d4d3187f237b70921
MD5 9c4f3b649f98d94c4fc8b6d7e3305281
BLAKE2b-256 84e810baf0945ec355822b4736a18567ca2ac97042d9bd4f22c9811d7e6edf37

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page