Python project for generating badges for your projects
Supports: Python 3.7-3.13 (2.7-3.6 support has been dropped)
anybadge
can be used to add badge generation to your Python projects,
and also provides a command line interface.
This utility can be used to generate .svg badge images, using configurable
thresholds for coloring the badges based on the badge value. Many badge
generation tools just provide the ability to specify the color of badge.
anybadge
allows you to specify the label, badge value, and color, but
it also allows you to specify a set of thresholds that can be used to
select a color based on the badge value.
anybadge
may be useful for companies developing internally, or any time
making calls to external badge services is not possible, or undesirable.
In this situation using anybadge
will be easier than running your own
internal badge service.
The package can be imported into your python code, or run direct from the command line.
You can find a repl.it demo here. This will allow you to see what the package can do and play with it to test outputs.
As an example, if you want to produce a pylint badge, you may run anybadge
from the command line like this:
anybadge -l pylint -v 2.22 -f pylint.svg 2=red 4=orange 8=yellow 10=green
This would result in a badge like this:
In this example the label is set to "pylint", the value "2.22", and an
output file called "pylint.svg". The thresholds are provided in pairs
of <value>=color
Values can be integer or floats for ranges, and
string values are also supported.
Here is the same example implemented in Python code:
import anybadge
# Define thresholds: <2=red, <4=orange <8=yellow <10=green
thresholds = {2: 'red',
4: 'orange',
6: 'yellow',
10: 'green'}
badge = anybadge.Badge('pylint', 2.22, thresholds=thresholds)
badge.write_badge('pylint.svg')
anybadge
is available in PyPi at https://pypi.python.org/pypi/anybadge
You can install the latest release of anybadge
using pip
:
pip install anybadge
This will install the Python package, and also make anybadge
available
as a command line utility.
To get help from the command line utility, just run:
anybadge --help
Running the utility with the --file
option will result in the .svg image being
written to file. Without the --file
option the .svg
file content will be
written to stdout, so can be redirected to a file.
Some thresholds have been built in to save time. To use these thresholds you can simply specify the template name instead of threshold value/color pairs.
anybadge --value=<VALUE> --file=<FILE> <TEMPLATE-NAME>
For example:
anybadge --value=2.22 --file=pylint.svg pylint
Anybadge comes with some pre-defined colors, which can be referred to by name. It also
supports the use of custom colors by using the hex representation of the color. Both color
types can be used in the default_color
, text_color
and thresholds
attributes. Color names are
taken from the Mozilla color keywords list.
Here is a Python example showing use of a named color and a custom color.
import anybadge
badge = anybadge.Badge(label='custom color', value='teal', default_color='teal', num_padding_chars=1)
badge = anybadge.Badge(label='custom color', value='teal', default_color='#008080', num_padding_chars=1)
Available named colors are:
It is possible to use emoji characters in badge labels and values. Here are some examples:
These files were created by using the actual emoji character in the label/value text. For example:
badge = anybadge.Badge(label="Pipeline status", value="π")
There are some caveats worth mentioning:
- The "look" of the emoji is determined by the client (Emoji characters are placed as-is into the SVG file, and are rendered client-side)
- Rendering may fail in some viewers and developer IDEs (for example, PyCharm does not render emojis in the svg viewer)
- Emojis can have different widths, so the layout may be affected. You can use
num_label_padding_chars
andnum_value_padding_chars
to fix (see below)
Here are some examples to show how to use padding to fix layout:
Badge | Code |
---|---|
anybadge.Badge("Pipeline status", "π") |
|
anybadge.Badge("Pipeline status", "π", num_value_padding_chars=1) |
It is possible to create badges with only a label or only a value. This can be done by passing an empty string to the appropriate field. Note that either a label or value must be provided.
Badge | Code |
---|---|
anybadge.Badge(label="Label only") |
|
anybadge.Badge(value="Value only") |
Anybadge supports semantic versions for value and threshold keys. This supports color-coded badges based on version numbering. Here are some examples:
badge = Badge(
label='Version',
value='3.0.0',
thresholds={'3.0.0': 'red', '3.2.0': 'orange', '999.0.0': 'green'},
semver=True
)
In the above example the thresholds equate to the following:
- If value is < 3.0.0 then badge will be red.
- If value is < 3.2.0 then badge will be orange.
- If value is < 999.0.0 then badge will be green.
Each threshold entry is used to define the upper bounds of the threshold. If you don't know the
upper bound for your version number threshold you will need to provide an extreme upper bound -
in this example it is 999.0.0
.
Badges are generated as .svg files, which utilize an XML-based markup language. Consequently, any HTML characters present in badge labels or values must be escaped to ensure proper representation. If you need to disable escaping, the following options are available:
- Python API
escape_label=False
escape_value=False
- CLI
--no-escape-label
--no-escape-value
anybadge --value=2.22 --file=pylint.svg pylint
anybadge -l pylint -v 2.22 -f pylint.svg 2=red 4=orange 8=yellow 10=green
anybadge --value=65 --file=coverage.svg coverage
anybadge --label=pipeline --value=passing --file=pipeline.svg passing=green failing=red
anybadge --label=awesomeness --value="110%" --file=awesomeness.svg --color='#97CA00'
anybadge --style=gitlab-scoped --label=Project --value=Archimedes --file=gitlab_scoped.svg --color='#c1115d'
anybadge --label=Version --value=2.4.5 --file=version.svg 1.0.0=red 2.4.6=orange 2.9.1=yellow 999.0.0=green
from anybadge import Badge
test1 = Badge(
label,
value,
font_name='DejaVu Sans,Verdana,Geneva,sans-serif',
font_size=11,
num_padding_chars=0.5,
template='<?xml version="1.0" encoding="UTF-8"?>\n<svg xmlns="http://www.w3.org/2000/svg" width="{{ badge width }}" height="20">\n <linearGradient id="b" x2="0" y2="100%">\n <stop offset="0" stop-color="#bbb" stop-opacity=".1"/>\n <stop offset="1" stop-opacity=".1"/>\n </linearGradient>\n <mask id="a">\n <rect width="{{ badge width }}" height="20" rx="3" fill="#fff"/>\n </mask>\n <g mask="url(#a)">\n <path fill="#555" d="M0 0h{{ color split x }}v20H0z"/>\n <path fill="{{ color }}" d="M{{ color split x }} 0h{{ value width }}v20H{{ color split x }}z"/>\n <path fill="url(#b)" d="M0 0h{{ badge width }}v20H0z"/>\n </g>\n <g fill="{{ label text color }}" text-anchor="middle" font-family="{{ font name }}" font-size="{{ font size }}">\n <text x="{{ label anchor shadow }}" y="15" fill="#010101" fill-opacity=".3">{{ label }}</text>\n <text x="{{ label anchor }}" y="14">{{ label }}</text>\n </g>\n <g fill="{{ value text color }}" text-anchor="middle" font-family="{{ font name }}" font-size="{{ font size }}">\n <text x="{{ value anchor shadow }}" y="15" fill="#010101" fill-opacity=".3">{{ value }}</text>\n <text x="{{ value anchor }}" y="14">{{ value }}</text>\n </g>\n</svg>',
value_prefix='',
value_suffix='',
thresholds=None,
default_color='#4c1',
use_max_when_value_exceeds=True,
value_format=None,
text_color='#fff'
)
test1.write_badge('test1.svg')
The command line options can be viewed using anybadge --help
.
Here are some usage specific command line examples that may save time on defining thresholds.
Pylint::
anybadge.py --value=2.22 --file=pylint.svg pylint
anybadge.py --label=pylint --value=2.22 --file=pylint.svg 2=red 4=orange 8=yellow 10=green
Coverage::
anybadge.py --value=65 --file=coverage.svg coverage
anybadge.py --label=coverage --value=65 --suffix='%%' --file=coverage.svg 50=red 60=orange 80=yellow 100=green
CI Pipeline::
anybadge.py --label=pipeline --value=passing --file=pipeline.svg passing=green failing=red
For Python API details you can use the inbuilt documentation:
from anybadge import badge
help(badge)