Skip to main content

Base class for creating enumerated constants that are also subclasses of str

Project description

A backport of (copy and paste from) python 3.11’s StrEnum class for >=3.8.6:

See the design discussion, and Ethan Furman’s first and second PR with this implementation.

A slightly different implementation would likely be compatible with lower python versions; PRs are welcome if they pass the test suite. The existing (reference) implementation should still be the one used on supported versions.

Install with pip install backports.strenum, and use with:

import sys

if sys.version_info >= (3, 11):
    from enum import StrEnum
else:
    from backports.strenum import StrEnum

class MyStrEnum(StrEnum):
    POTATO = "potato"
    ORANGE = "orange"
    SPADE = "spade"

MyStrEnum.POTATO == "potato"  # True
MyStrEnum.ORANGE.upper() == "ORANGE"  # True
str(MyStrEnum.SPADE) == "spade"  # True

From version 1.3.0, this package cannot be installed on python >=3.11. It shouldn’t be used on them anyway. Make sure that in your package, this is a conditional dependency.

Gotchas

A number of behaviours relating to the treatment of enum classes as containers of their members (e.g. iterating and containment checks) will be changing in python 3.12.

This package intends only to allow pre-3.11 users to get 3.11-like behaviour; after that, stick with the standard library.


These are the docs provided with python 3.11:

class enum.StrEnum

StrEnum is the same as Enum, but its members are also strings and can be used in most of the same places that a string can be used. The result of any string operation performed on or with a StrEnum member is not part of the enumeration.

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

backports_strenum-1.3.1.tar.gz (7.3 kB view details)

Uploaded Source

Built Distribution

backports_strenum-1.3.1-py3-none-any.whl (8.3 kB view details)

Uploaded Python 3

File details

Details for the file backports_strenum-1.3.1.tar.gz.

File metadata

  • Download URL: backports_strenum-1.3.1.tar.gz
  • Upload date:
  • Size: 7.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.7

File hashes

Hashes for backports_strenum-1.3.1.tar.gz
Algorithm Hash digest
SHA256 77c52407342898497714f0596e86188bb7084f89063226f4ba66863482f42414
MD5 32c30ec0cf37836f5482e153a945ba38
BLAKE2b-256 35c72ed54c32fed313591ffb21edbd48db71e68827d43a61938e5a0bc2b6ec91

See more details on using hashes here.

File details

Details for the file backports_strenum-1.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for backports_strenum-1.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 cdcfe36dc897e2615dc793b7d3097f54d359918fc448754a517e6f23044ccf83
MD5 25337266b035a8b43ab84ce9288cec4b
BLAKE2b-256 d65056cf20e2ee5127b603b81d5a69580a1a325083e2b921aa8f067da83927c0

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