Skip to main content

Advanced Enumerations (compatible with Python's stdlib Enum), NamedTuples, and NamedConstants

Project description

Advanced Enumerations (compatible with Python’s stdlib Enum), NamedTuples, and NamedConstants

WARNING: Version 3.1 has breaking changes in custom Enum settings WARNING: WARNING: AutoNumber has been removed WARNING: AutoValue has been removed

aenum includes a Python stdlib Enum-compatible data type, as well as a metaclass-based NamedTuple implementation and a NamedConstant class.

An Enum is a set of symbolic names (members) bound to unique, constant values. Within an enumeration, the members can be compared by identity, and the enumeration itself can be iterated over. Support exists for unique values, multiple values, auto-numbering, and suspension of aliasing (members with the same value are not identical), plus the ability to have values automatically bound to attributes.

A NamedTuple is a class-based, fixed-length tuple with a name for each possible position accessible using attribute-access notation as well as the standard index notation.

A NamedConstant is a class whose members cannot be rebound; it lacks all other Enum capabilities, however.

Enum classes:

  • Enum: Base class for creating enumerated constants.

  • IntEnum: Base class for creating enumerated constants that are also

    subclasses of int.

  • Flag: Base class for creating enumerated constants that can be combined

    using the bitwise operations without losing their Flag membership.

  • IntFlag: Base class for creating enumerated constants that can be combined

    using the bitwise operators without losing their IntFlag membership. IntFlag members are also subclasses of int.

  • AutoNumberEnum: Derived class that automatically assigns an int value to each

    member.

  • OrderedEnum: Derived class that adds <, <=, >=, and > methods to an Enum.

  • UniqueEnum: Derived class that ensures only one name is bound to any one

    value.

Utility functions include:

  • convert: helper to convert target global variables into an Enum

  • constant: helper class for creating constant members

  • enum: helper class for creating members with keywords

  • enum_property: property to enable enum members to have same named attributes

    (e.g. name and value)

  • export: helper to insert Enum members into a namespace (usually globals())

  • extend_enum: add new members to enumerations after creation

  • module: inserts NamedConstant and Enum classes into sys.modules

    where it will appear to be a module whose top-level names cannot be rebound

  • skip: class that prevents attributes from being converted to a

    constant or enum member

  • unique: decorator that ensures no duplicate members

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

aenum-3.1.1.tar.gz (125.2 kB view details)

Uploaded Source

Built Distributions

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

aenum-3.1.1-py3-none-any.whl (127.6 kB view details)

Uploaded Python 3

aenum-3.1.1-py2-none-any.whl (115.7 kB view details)

Uploaded Python 2

File details

Details for the file aenum-3.1.1.tar.gz.

File metadata

  • Download URL: aenum-3.1.1.tar.gz
  • Upload date:
  • Size: 125.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/58.1.0 requests-toolbelt/0.9.1 tqdm/4.57.0 CPython/3.9.7+

File hashes

Hashes for aenum-3.1.1.tar.gz
Algorithm Hash digest
SHA256 75b96aa148e1335eae6c12015563989a675fcbd0bcbd0ae7ce5786329278929b
MD5 8c0f594877c0b1fd06ae8235211a5414
BLAKE2b-256 9a07c23d13d2fd0f42a2c8559f9ad1e9eb7b13ea5f14f546c54999676d712acd

See more details on using hashes here.

File details

Details for the file aenum-3.1.1-py3-none-any.whl.

File metadata

  • Download URL: aenum-3.1.1-py3-none-any.whl
  • Upload date:
  • Size: 127.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/58.1.0 requests-toolbelt/0.9.1 tqdm/4.57.0 CPython/3.9.7+

File hashes

Hashes for aenum-3.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 e2f2639bc05dd6f1e084cee1d949211c9d5cfa454329211905d81a585ea9cd92
MD5 28c8f343649bd4dfc7290def9f6c297b
BLAKE2b-256 ea6629d999e1f3a1ffca5b307ca5be81c1ca82edd15ef1194fe150135e37ae28

See more details on using hashes here.

File details

Details for the file aenum-3.1.1-py2-none-any.whl.

File metadata

  • Download URL: aenum-3.1.1-py2-none-any.whl
  • Upload date:
  • Size: 115.7 kB
  • Tags: Python 2
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/58.1.0 requests-toolbelt/0.9.1 tqdm/4.57.0 CPython/3.9.7+

File hashes

Hashes for aenum-3.1.1-py2-none-any.whl
Algorithm Hash digest
SHA256 35eeb0476ee72c7e9bddee0df48c91f07644c33f06da4e30ff41d7c85d025579
MD5 55f16dcf8a5a1da5bc9a9b92634a9126
BLAKE2b-256 126ca55da1e684d76a047003efc2d4e0c513d8555003610d9b7da5c3a61538c2

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