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

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-2.2.2.tar.gz (106.0 kB view details)

Uploaded Source

Built Distributions

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

aenum-2.2.2-py3-none-any.whl (40.6 kB view details)

Uploaded Python 3

aenum-2.2.2-py2-none-any.whl (33.7 kB view details)

Uploaded Python 2

File details

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

File metadata

  • Download URL: aenum-2.2.2.tar.gz
  • Upload date:
  • Size: 106.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.18.4 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/2.7.15rc1

File hashes

Hashes for aenum-2.2.2.tar.gz
Algorithm Hash digest
SHA256 c94fde69eebf8d478d68f0d96c61178299d9a19465ef5effa326ebee7536c203
MD5 9d5d9d846c24b2aa656bf477bc5a8e7f
BLAKE2b-256 00db6f60b39f91981b8b2811da5cb9fe989ae1ed2a424ae937f1a731ad4be945

See more details on using hashes here.

File details

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

File metadata

  • Download URL: aenum-2.2.2-py3-none-any.whl
  • Upload date:
  • Size: 40.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.18.4 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/2.7.15rc1

File hashes

Hashes for aenum-2.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 1aeed99d78f708b1a27cb6d1564c571acb3c2a345a5c67d4e2e1d06200552381
MD5 a8063153961c510bbf560e8da9b5af12
BLAKE2b-256 4908a3eabfedec5ec2934ee3d47ac68cb06a243fa99fe23877ab5b16a5b5fbef

See more details on using hashes here.

File details

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

File metadata

  • Download URL: aenum-2.2.2-py2-none-any.whl
  • Upload date:
  • Size: 33.7 kB
  • Tags: Python 2
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/1.13.0 pkginfo/1.5.0.1 requests/2.18.4 setuptools/41.0.1 requests-toolbelt/0.9.1 tqdm/4.32.2 CPython/2.7.15rc1

File hashes

Hashes for aenum-2.2.2-py2-none-any.whl
Algorithm Hash digest
SHA256 5385b363c22cb7b87d44ed086dd7c6142a0bf0f997cfeaf67596cc7a700c4070
MD5 f2633b16738f503d70196da170eac682
BLAKE2b-256 c5775ef32df510271483eb0c8f8c37e21312acc861d42642a440a7957f5999d6

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