python-attrs
Port variant py39
Summary Classes Without Boilerplate (3.9)
Package version 22.1.0
Homepage https://www.attrs.org/
Keywords python
Maintainer Python Automaton
License Not yet specified
Other variants py310
Ravenports Buildsheet | History
Ravensource Port Directory | History
Last modified 07 AUG 2022, 15:44:05 UTC
Port created 06 AUG 2019, 14:27:27 UTC
Subpackage Descriptions
single .. image:: https://www.attrs.org/en/stable/_static/attrs_logo.png :alt: attrs logo :align: center attrs is the Python package that will bring back the **joy** of **writing classes** by relieving you from the drudgery of implementing object protocols (aka [dunder methods]). [Trusted by NASA] for Mars missions since 2020! Its main goal is to help you to write **concise** and **correct** software without slowing down your code. .. teaser-end For that, it gives you a class decorator and a way to declaratively define the attributes on that class: .. -code-begin- .. code-block:: pycon >>> from attrs import asdict, define, make_class, Factory >>> @define ... class SomeClass: ... a_number: int = 42 ... list_of_numbers: list[int] = Factory(list) ... ... def hard_math(self, another_number): ... return self.a_number + sum(self.list_of_numbers) * another_number >>> sc = SomeClass(1, [1, 2, 3]) >>> sc SomeClass(a_number=1, list_of_numbers=[1, 2, 3]) >>> sc.hard_math(3) 19 >>> sc == SomeClass(1, [1, 2, 3]) True >>> sc != SomeClass(2, [3, 2, 1]) True >>> asdict(sc) {'a_number': 1, 'list_of_numbers': [1, 2, 3]} >>> SomeClass() SomeClass(a_number=42, list_of_numbers=[]) >>> C = make_class("C", ["a", "b"]) >>> C("foo", "bar") C(a='foo', b='bar') After *declaring* your attributes, attrs gives you: - a concise and explicit overview of the class's attributes, - a nice human-readable __repr__, - equality-checking methods, - an initializer, - and much more, *without* writing dull boilerplate code again and again and *without* runtime performance penalties. **Hate type annotations**!? No problem! Types are entirely **optional** with attrs. Simply assign ``attrs.field()`` to the attributes instead of annotating them with types. ---- This example uses attrs's modern APIs that have been introduced in version 20.1.0, and the attrs package import name that has been added in version 21.3.0. The classic APIs (``@attr.s``, ``attr.ib``, plus their serious-business aliases) and the attr package import name will remain **indefinitely**. Please check out [On The Core API Names] for a more in-depth explanation. Data Classes ============ On the tin, attrs might remind you of dataclasses (and indeed, dataclasses [are a descendant] of attrs). In practice it does a lot more and is more flexible. For instance it allows you to define [special handling of NumPy arrays for equality checks], or allows more ways to [plug into the initialization process]. For more details, please refer to our [comparison page]. .. -project-information- Project Information =================== - **License**: [MIT] - **PyPI**: https://pypi.org/project/attrs/
Configuration Switches (platform-specific settings discarded)
PY310 OFF Build using Python 3.10 PY39 ON Build using Python 3.9
Package Dependencies by Type
Build (only) python-pip:single:py39
autoselect-python:single:standard
Build and Runtime python39:single:standard
Download groups
main mirror://PYPIWHL/f2/bc/d817287d1aa01878af07c19505fafd1165cd6a119e9d0821ca1d1c20312d
Distribution File Information
86efa402f67bf2df34f51a335487cf46b1ec130d02b8d39fd248abfd30da551c 58795 attrs-22.1.0-py2.py3-none-any.whl
Ports that require python-attrs:py39
python-Automat:py39 Self-service finite-state machines (3.9)
python-Twisted:py39 Asynchronous networking framework (3.9)
python-aiohttp:py39 Async http client/server framework (3.9)
python-cattrs:py39 Composable complex class support for attrs (3.9)
python-jsonschema:py39 Alternate implementation of JSON Schema (3.9)
python-statmake:py39 Applies STAT Stylespace to a variable font (3.9)
python-ufoLib2:py39 UfoLib2 is a UFO font processing library (3.9)