Skip to main content

Python library for adding basic geometric shapes directly to PowerPoint (.pptx) slides by editing the XML structure.

Project description

pptx-shapes

PyPI version License: MIT Documentation Status CI tests

Python library for adding basic geometric shapes directly to PowerPoint (.pptx) slides by editing the XML structure.

Example

Features

  • Add basic shapes (ellipse, line, polygon, etc.) to existing slides
  • Control position, size, fill, stroke, and other styles
  • Simple, expressive API with smart defaults
  • Supports minimalistic charts such as donut, bar, scatter charts
  • Work directly with slides XML structure
  • Save result as .pptx

Installation

pip install pptx-shapes

Quick Start

from pptx_shapes import Presentation
from pptx_shapes.shapes import Ellipse, Rectangle, TextBox
from pptx_shapes.style import FillStyle, FontFormat, FontStyle, StrokeStyle

with Presentation(presentation_path="empty.pptx") as presentation:
    presentation.add(shape=TextBox(
        x=23, y=4, width=12, height=2, angle=45,
        text="Hello from pptx-shapes!",
        style=FontStyle(size=32),
        formatting=FontFormat(bold=True)
    ))

    presentation.add(shape=Ellipse(
        x=20, y=2, width=4, height=4,
        fill=FillStyle(color="#7699d4")
    ))

    presentation.add(shape=Rectangle(
        x=18, y=8, width=4, height=8.5, radius=0.25, angle=30,
        fill=FillStyle(color="#dd7373"),
        stroke=StrokeStyle(color="magenta", thickness=3)
    ))

    presentation.save("result.pptx")

How it works

This library modifies .pptx files by directly editing the underlying XML structure.

A .pptx presentation is essentially a ZIP archive containing XML files that describe slides, layouts, and content. This library works by:

  • Unzipping the .pptx file.
  • Locating and parsing the target slide file (e.g., ppt/slides/slide1.xml).
  • Inserting new shape elements into the slide's XML tree, using tags like <p:sp>, <p:cxnSp>, and <a:prstGeom>.
  • Saving the modified XML.
  • Repacking all files into a .pptx archive.

This low-level approach is ideal for automated slide generation, data visualizations, and geometric illustrations – especially when you need to create many shapes or apply programmatic styles.

Supported Shapes

Currently, pptx-shapes supports the following geometric shapes:

Shape Class Description
Line Line Straight line between two points
Arrow Arrow Straight arrow between two points
Arc Arc Curved segment defined by the bounding box and start/end angles
Arch Arch Ring-shaped arc defined by the bounding box, thickness and start/end angles
Ellipse Ellipse Ellipse defined by top-left corner, size, and rotation angle
Rectangle Rectangle Rectangle defined by top-left corner, size, corner radius and rotation angle
Pie Pie Filled sector of a circle, defined by the bounding box and start/end angles
Polygon Polygon Arbitrary polygon defined by a list of points and rotation angle
TextBox TextBox Text container with position, size, rotation, and font style
Group Group A group of multiple shapes

Supported charts

The pptx_shapes.charts module provides classes for adding simple charts to PowerPoint presentations using basic shapes.

Chart Class Description
Donut DonutChart A donut chart used to visualize proportions of categorical data.
Bar BarChart A bar chart used to display values across categories or time series.
Scatter ScatterPlot A scatter plot used to visualize a set of points on a coordinate plane.

Documentation

Full documentation and examples are available at pptx-shapes.readthedocs.io

Examples

The following examples illustrate how to generate PowerPoint slides with various geometric shapes using pptx-shapes. All examples include screenshots, downloadable .pptx files, and links to the corresponding source code.

Example 1. Basic shapes

A simple demonstration of how to draw basic geometric elements – lines, ellipses, rectangles, polygons, arrows and text – on a blank slide (examples/basic.py).

Basic example

Download .pptx: examples/basic.pptx

Example 2. Scatter plots

This example shows how to render a scatter plot using ellipses as data points, demonstrating precise positioning and styling (examples/scatter.py).

Simple scatter example

Download .pptx: examples/scatter.pptx

Example 3. Histograms

Bar-style visualizations built using rectangles – this example illustrates how to construct a histogram layout with custom colors (examples/histogram.py).

Simple histogram example

Download .pptx: examples/histogram.pptx

Example 4. Polygons split

A more advanced use case – splitting polygonal shapes by lines. Useful for illustrating partitions or segmentations (examples/polygons.py).

Polygons split example

Download .pptx: examples/polygons.pptx

Example 5. Font families and text styles

This example demonstrates how to use different font families and styles in TextBox shapes. It shows how to customize font size, alignment, color, and the font family. (examples/text_boxes.py).

Font styles example

Download .pptx: examples/text_boxes.pptx

Example 6. Arrowhead styles

This example demonstrates how to use different arrowhead types for Arrow shapes. It shows how to customize head form, length and width of arrowhead. (examples/arrows.py).

Arrowhead styles example

Download .pptx: examples/arrows.pptx

Chart examples

Example 1. Donut charts

This example demonstrates how to use DonutChart from charts.donut module (examples/charts/donut_chart.py).

Donut chart example

Download .pptx: examples/charts/donut_chart.pptx

Example 2. Bar chart

This example demonstrates how to use BarChart from charts.bar module (examples/charts/bar_chart.py).

Bar chart example

Download .pptx: examples/charts/bar_chart.pptx

Example 3. Scatter plot

This example demonstrates how to use ScatterPlot from charts.scatter module (examples/charts/scatter_plot.py).

Scatter plot example

Download .pptx: examples/charts/scatter_plot.pptx

Changelog

See CHANGELOG.md for version history.

License

Licensed under the MIT License. Feel free to use it in your projects.

Contributing

Pull requests, issues, and feature ideas are very welcome!

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

pptx_shapes-0.3.0.tar.gz (20.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

pptx_shapes-0.3.0-py3-none-any.whl (29.9 kB view details)

Uploaded Python 3

File details

Details for the file pptx_shapes-0.3.0.tar.gz.

File metadata

  • Download URL: pptx_shapes-0.3.0.tar.gz
  • Upload date:
  • Size: 20.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.0

File hashes

Hashes for pptx_shapes-0.3.0.tar.gz
Algorithm Hash digest
SHA256 1d22f0b2b5904ed2e56b5ab0623d554596ed2334b2d51fc55578cf03e4570c5d
MD5 047a6e996bd2d99071e48f9d0a318d3d
BLAKE2b-256 3b6ced8aaecf4994a1edb4cf72aab7328493eb8880f672ffe1da24cce8b96bbe

See more details on using hashes here.

File details

Details for the file pptx_shapes-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: pptx_shapes-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 29.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.0

File hashes

Hashes for pptx_shapes-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 b0ce5ff057cf778214f448851a19c5057982b47eb5d78f1a15478f362c4bf7b9
MD5 843ce7ff3aa905a269771f4a5f73a982
BLAKE2b-256 fcecce567f5c160690e618816e468f13bc3bb55b7d8453c2f0065608c800de25

See more details on using hashes here.

Supported by

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