Object destructuring of function parameters for Python!
Project description
More KWARGS!
Object destructuring of function parameters for Python!
Motivation
Javascript has object destructuring, and it can be used for function parameters. This has a couple of benefts over Python's keyword arguments:
- Extra caller parameters are ignored (eg
f({a, b, c})) - Duplicate parameters are handled elegantly (eg
f({a, a}))
The mo-kwargs library provides this functionality with the @override decorator, with additional benefits:
- required parameters throw an error if missing, just like regular Python
- all parameters, even ones not in the argument list, are passed in the optional
kwargsparameter
The @override decorator adds a kwargs argument which can be passed a dict of call parameters; but unlike **kwargs, it will not raise duplicate key exceptions.
Provide default values
We decorate the login() function with @override. username is a required parameter, and password will default to None.
@override
def login(username, password=None):
pass
Define some dicts for use with our kwargs parameter:
creds = {"userame": "ekyle", "password": "password123"}
alt_creds = {"username": "klahnakoski"}
The simplest case is when we use kwargs with no overrides
login(kwargs=creds)
# SAME AS
login(**creds)
# SAME AS
login(username="ekyle", password="password123")
You may override any property in kwargs: In this case it is password
login(password="123", kwargs=creds)
# SAME AS
login(username="ekyle", password="123")
There is no problem with overriding everything in kwargs:
login(username="klahnakoski", password="asd213", kwargs=creds)
# SAME AS
login(username="klahnakoski", password="asd213")
You may continue to use **kwargs; which provides a way to overlay one parameter template (creds) with another (alt_creds)
login(kwargs=creds, **alt_creds)
# SAME AS
login(username="klahnakoski", password="password123")
Handle too many parameters
Sometimes your method parameters come from a configuration file, or some other outside source which is outside your control. There may be more parameters than your method is willing to accept.
creds = {"username": "ekyle", "password": "password123", "port":9000}
def login(username, password=None):
print(kwargs.get("port"))
Without mo-kwargs, passing the creds dictionary directly to login() would raise a key error
>>> login(**creds)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: login() got an unexpected keyword argument 'port'
The traditional solution is to pass the parameters explicitly:
login(username=creds.username, password=creds.password)
but that can get get tedious when done often, or the parameter list get long. mo-kwargs allows you to pass the whole dictionary to the kwargs parameter; only the parameters used by the method are used:
@override
def login(username, password=None):
pass
login(kwargs=creds)
# SAME AS
login(username=creds.username, password=creds.password)
Package all parameters
Your method can accept kwargs as a parameter. If it does, ensure it defaults to None so that it's not required.
@override
def login(username, password=None, kwargs=None):
print(kwargs.get("username"))
print(kwargs.get("port"))
kwargs will always be a dict, possibly empty, with the full set of parameters. This is different from using **kwargs which contains only the remainder of the keyword parameters.
>>> creds = {"username": "ekyle", "password": "password123", "port":9000}
>>> login(**creds)
ekyle
9000
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 mo_kwargs-7.685.25166.tar.gz.
File metadata
- Download URL: mo_kwargs-7.685.25166.tar.gz
- Upload date:
- Size: 11.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9dbc3676e2db65a1810d8e61162e90bc62ee4b8e61153b8831ef2c6c7c216f42
|
|
| MD5 |
3208cf4f22ad598c55097f17a4ddb1d3
|
|
| BLAKE2b-256 |
90e72bae60869185907803fd151bda1b8f5d2a68f010cba11e77da4b9ea3dcd9
|
File details
Details for the file mo_kwargs-7.685.25166-py3-none-any.whl.
File metadata
- Download URL: mo_kwargs-7.685.25166-py3-none-any.whl
- Upload date:
- Size: 10.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.13.1
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a6296cd4cbf4900bb032d67c23b53a08bcf4bc5a8986ee4e8514b89eef7e6cef
|
|
| MD5 |
594f989d1dd32b9f28406a0a55977bb4
|
|
| BLAKE2b-256 |
d2305b5ed1b8c7954a5edf1d59917127d203d34f4f25c44b63bb86219e25d37f
|