Mixin which converts ``data class instance`` and others each other more simple.
Project description
OwlMixin
(゚∀゚) v5.0 have breaking changes
TIterator#group_by- Return
TDict[TList[T]]instead ofTDict[TIterator[T]]
- Return
(゚∀゚) v4.0 have breaking changes
OwlMixin- Must use keyword arguments in
from_XXXandto_XXXexcept for some ones from_csvf->from_csvf_to_list
- Must use keyword arguments in
TListhead->takepartial->partition(switch left and right)
transformers.XXX- Must use keyword arguments in
to_dictto_dictsto_jsonto_jsonfto_yamlto_yamlfto_csvto_csvf
- Must use keyword arguments in
💪 Motivation
Have you ever wanted to write robust code in Python? This library will make such your wishes come true.
Define your data class which is extend OwlMixin, you can use some useful methods which help your codes robust.
See following Example and API Reference sections.
💃 Installation
pip install owlmixin
📜 API Reference
https://tadashi-aikawa.github.io/owlmixin/
👉 Examples
from owlmixin import OwlMixin, OwlEnum, TOption, TList
class Color(OwlEnum):
RED = "red"
GREEN = "green"
BLUE = "blue"
class Food(OwlMixin):
id: int
name: str
color: TOption[Color]
class Human(OwlMixin):
id: int
name: str
favorite: TList[Food]
jiro = Human.from_dict({
"id": 10,
"name": "jiro",
"favorite": [
{"id": 1, "name": "apple"},
{"id": 2, "name": "orange", "color": "green"}
]
})
Then...
>>> jiro.id
10
>>> jiro.name
'jiro'
>>> print(jiro.to_dict())
{'id': 10, 'name': 'jiro', 'favorite': [{'id': 1, 'name': 'apple'}, {'id': 2, 'name': 'orange', 'color': 'green'}]}
>>> print(jiro.favorite[0].to_pretty_json())
{
"id": 1,
"name": "apple"
}
>>> print(jiro.to_yaml())
favorite:
- id: 1
name: apple
- color: green
id: 2
name: orange
id: 10
name: jiro
>>> print(jiro.favorite.to_csv(['id', 'name', 'color'], with_header=True))
id,name,color
1,apple,
2,orange,green
You can also use methods chains as following.
from owlmixin import OwlMixin, TOption, TIterator
class Repository(OwlMixin):
id: int
name: str
description: TOption[str]
stargazers_count: int
class GithubRepository(OwlMixin):
total_count: int
incomplete_results: bool
items: TIterator[Repository]
Then...
>>> print(
... GithubRepository
... .from_json_url("https://api.github.com/search/repositories?q=git")
... .items
... .filter(lambda x: x.stargazers_count > 100)
... .order_by(lambda x: x.stargazers_count, True)
... .take(5)
... .emap(lambda v, i: {
... 'RANK': i+1,
... 'STAR': v.stargazers_count,
... 'NAME': v.name,
... 'DESCRIPTION': v.description
... })
... .to_csv(fieldnames=["RANK", "STAR", "NAME", "DESCRIPTION"], with_header=True)
... )
RANK,STAR,NAME,DESCRIPTION
1,84643,gitignore,A collection of useful .gitignore templates
2,30456,gogs,Gogs is a painless self-hosted Git service.
3,29908,git-flight-rules,Flight rules for git
4,27704,git,Git Source Code Mirror - This is a publish-only repository and all pull requests are ignored. Please follow Documentation/SubmittingPatches procedure for any of your improvements.
5,15541,tips,Most commonly used git tips and tricks.
Don't you think smart?
💻 For developers
Requirements
- uv
- make
Flow
- Development on master and if you need branches and issues, create them
- Use the Conventional Commits message
Commands
# Create env
$ uv run
# Build documentation and run server locally
$ make serve-docs
# Test (Doc test & Unit test)
$ make test
📦 Release
https://github.com/tadashi-aikawa/owlmixin/actions/workflows/release.yaml?query=workflow%3ARelease
(Appendix) Another way
If you can't or don't want to use GitHub Actions, you can release locally as following.
(a1) Requirements
- Windows is not supported!!!
- uv (with pypi authentications)
- make
(a2) Commands
make release version=x.y.z
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file owlmixin-7.0.1.tar.gz.
File metadata
- Download URL: owlmixin-7.0.1.tar.gz
- Upload date:
- Size: 155.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.5.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
de153f701299aeed06078e51140a49d287dcf57ae0a095a01a160f57bc5abc93
|
|
| MD5 |
b294ae60b1bd042276fdd1f7675352f9
|
|
| BLAKE2b-256 |
00916d46a74a3dccf38f6dd9f9422868193962e10320ca6b15c787d391059beb
|
File details
Details for the file owlmixin-7.0.1-py3-none-any.whl.
File metadata
- Download URL: owlmixin-7.0.1-py3-none-any.whl
- Upload date:
- Size: 20.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.5.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
eae5983bbf6325c744ef54ce2916da18f01f171f3c4d3c4f243fc335b6c68f8f
|
|
| MD5 |
26dab7b8ce0feef1c0e6d8081733a075
|
|
| BLAKE2b-256 |
13471a8288fb24252ddad567cf3c54595880a1a2c05e2ab87ca3a560ae681fd8
|