A library and command-line tool for generating Github-style badges
Project description
badgepy
badgepy is a fork of google/pybadges with fixes including Python 3.13+ support, dropped Python 3.7/3.8 support, removal of deprecated
imghdr, and replacement ofpkg_resourcesand many other fixes. This project is actively maintained.
badgepy is a Python library and command line tool that allows you to create GitHub-style badges as SVG images.
The aesthetics of the generated badges matches the visual design found in this specification.
The implementation of the library was heavily influenced by Shields.io and the JavaScript badge-maker library.
Getting Started
Installing
badgepy can be installed using pip:
pip install badgepy
To test that installation was successful, try:
python -m badgepy --left-text=build --right-text=failure --right-color='#c00' --browser
You will see a badge like this in your browser:
Usage
badgepy can be used both from the command line and as a Python library.
The command line interface is a great way to experiment with the API before writing Python code.
You could also look at the example server.
Command line usage
Complete documentation of badgepy command arguments can be found using the --help
flag:
badgepy --help
But the following usage demonstrates every interesting option:
badgepy \
--left-text=complete \
--right-text=example \
--left-color=green \
--right-color='#fb3' \
--left-link=http://www.complete.com/ \
--right-link=http://www.example.com \
--logo='data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAIAAAACCAIAAAD91JpzAAAAD0lEQVQI12P4zwAD/xkYAA/+Af8iHnLUAAAAAElFTkSuQmCC' \
--embed-logo \
--whole-title="Badge Title" \
--left-title="Left Title" \
--right-title="Right Title" \
--browser
A note about --logo and --embed-logo
Note that the --logo option can include a regular URL:
badgepy \
--left-text="python" \
--right-text="3.9, 3.10, 3.11, 3.12, 3.13, 3.14" \
--whole-link="https://www.python.org/" \
--browser \
--logo='https://dev.w3.org/SVG/tools/svgweb/samples/svg-files/python.svg'
If the --logo option is set, the --embed-logo option can also be set.
The --embed-logo option causes the content of the URL provided in --logo
to be embedded in the badge rather than be referenced through a link.
The advantage of using this option is an extra HTTP request will not be required to render the badge and that some browsers will not load image references at all.
A note about --(whole|left|right)-title
The title element is usually displayed as a
pop-up by browsers
but is currently
filtered by Github.
Library usage
badgepy is primarily meant to be used as a Python library.
from badgepy import badge
s = badge(left_text='coverage', right_text='23%', right_color='red')
# s is a string that contains the badge data as an svg image.
print(s[:40]) # => <svg height="20" width="191.0" xmlns="ht
The keyword arguments to badge() are identical to the command flags names
described above except with keyword arguments using underscore instead of
hyphen/minus (e.g. --left-text => left_text=)
Server usage
badgepy can be used to serve badge images on the web.
server-example contains an example of serving badge images from a Flask server.
Caveats
-
badgepy uses a pre-calculated table of text widths and kerning distances (for western glyphs) to determine the size of the badge. So Eastern European languages may be rendered less well than Western European ones.
and glyphs not present in Deja Vu Sans (the default font) may be rendered very poorly.
-
badgepy does not have any explicit support for languages that are written right-to-left (e.g. Arabic, Hebrew) and the displayed text direction may be incorrect.
Development
git clone https://github.com/shenxianpeng/badgepy.git
cd badgepy
python -m venv venv
source venv/bin/activate
# Installs in editable mode with development dependencies.
pip install -e .[dev]
nox
If you'd like to contribute your changes back to badgepy, please read the contributor guide.
Versioning
We use SemVer for versioning.
License
This project is licensed under the Apache License - see the LICENSE file for details.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distributions
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file badgepy-1.2.1-py3-none-any.whl.
File metadata
- Download URL: badgepy-1.2.1-py3-none-any.whl
- Upload date:
- Size: 61.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
cefcd324aadec86e5f7869d9ab4218714416640582eceec70c21befbbfe75dc6
|
|
| MD5 |
9fa389bbca90bb47749abadd9df95014
|
|
| BLAKE2b-256 |
cd985a87a21d23de0715e7a2d36cf90f3355ef4a70bd170fd4c6aa61c9d73aa7
|