by ericvsmith

ericvsmith / dataclasses
443 Stars 40 Forks Last release: Not found Apache License 2.0 286 Commits 8 Releases

Available items

No Items, yet!

The developer of this repository has not created any items for sale yet. Need a bug fixed? Help with integration? A different license? Create a request here:

.. image:: :target:

This is an implementation of PEP 557, Data Classes. It is a backport for Python 3.6. Because dataclasses will be included in Python 3.7, any discussion of dataclass features should occur on the python-dev mailing list at At this point this repo should only be used for historical purposes (it's where the original dataclasses discussions took place) and for discussion of the actual backport to Python 3.6.

See for the details of how Data Classes work.

A test file can be found at, or in the sdist file.


.. code-block::

pip install dataclasses

Example Usage

.. code-block:: python

from dataclasses import dataclass

@dataclass class InventoryItem: name: str unitprice: float quantityon_hand: int = 0

  def total_cost(self) -> float:
      return self.unit_price * self.quantity_on_hand

item = InventoryItem('hammers', 10.49, 12) print(item.total_cost())

Some additional tools can be found in, included in the sdist.


This backport assumes that dict objects retain their insertion order. This is true in the language spec for Python 3.7 and greater. Since this is a backport to Python 3.6, it raises an interesting question: does that guarantee apply to 3.6? For CPython 3.6 it does. As of the time of this writing, it's also true for all other Python implementations that claim to be 3.6 compatible, of which there are none. Any new 3.6 implementations are expected to have ordered dicts. See the analysis at the end of this email:

As of version 0.4, this code no longer works with Python 3.7. For 3.7, use the built-in dataclasses module.

Release History

+---------+------------+-------------------------------------+ | Version | Date | Description | +=========+============+=====================================+ | 0.7 | 2019-10-20 | Require python 3.6 only | +---------+------------+-------------------------------------+ | 0.6 | 2018-05-17 | Equivalent to Python 3.7.0rc1 | +---------+------------+-------------------------------------+ | 0.5 | 2018-03-28 | Equivalent to Python 3.7.0b3 | +---------+------------+-------------------------------------+

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.