A tool to automatically remove extra calls to keys().
Project description
unkey
A tool and pre-commit hook to automatically remove extra calls to keys()
.
Installation
pip install unkey
As a pre-commit hook
See pre-commit for instructions
Sample .pre-commit-config.yaml
:
- repo: https://github.com/mxr/unkey
rev: v0.0.1
hooks:
- id: unkey
Overview
Summary
Iterating over a Python dictionary will iterate over its keys, so calls to
keys()
are often not needed. Removing these calls keeps your code terser and
more readable.
Excluding Code
unkey
does not support an equivalent of flake8's # noqa
or mypy's #type: ignore
to stop rewriting. Until this feature is available, use an intermediate
variable to prevent rewriting.
# will be rewritten
min({1: 2, 3: 4}.keys()) # becomes min({1: 2, 3: 4})
# will not be rewritten
keys = {1: 2, 3: 4}.keys()
min(keys)
Disclaimer
Since AST parsing does not always tell us the type of an object, there may be false positives and unsedsirable rewrites or bugs. With that said the tool is designed to err on the side of not rewriting rather than being very clever and rewriting as much as possible. To exclude rewrite, see the above section. PRs are always welcome to help out!
Features
builtins
Rewrites builtin calls that have iterable arguments
# simple cases
-min({1: 2, 3: 4}.keys())
+min({1: 2, 3: 4})
-min(d.keys())
+min(d)
-min(f().keys())
+min(f())
# more complex cases
-min(d1().x.y(1, 2 ,3, (4, 5)).keys())
+min(d1().x.y(1, 2, 3, (4, 5)))
zip
Rewrites relevant arguments in zip()
-zip(d.keys(), {}.keys(), f().keys(), [1, 2, 3])
+zip(d, {}, f(), [1, 2, 3])
map
/ filter
Rewrites relevant arguments in map
and filter
-map(lambda x: x*2, d.keys())
+map(lambda x: x*2, d)
-filter(None, d.keys())
+filteR(None, d)
in
Rewrites relevant comparisons using in
-if x in d.keys():
+if x in d:
pass
comprehensions
Rewrites relevant list/dict/set comprehensions and generator expressions
-[x for x in d.keys()]
+[x for x in d]
-(x for x in d.keys())
+(x for x in d)
-{x for x in d.keys()}
+{x for x in d}
-{x: x for x in d.keys()}
+{x: x for x in d}
Iteration
Rewrites iteration
-for _ in d.keys(): pass
+for _ in d: pass
-for _ in {}.keys(): pass
+for _ in {}: pass
-for _ in f().keys(): pass
+for _ in f(): pass
For additional linting in this space check out flake8-comprehensions
.
Acknowledgements
This tool would not be possible without guidance and tools from Anthony
Sottile, specifically, pyupgrade
and
pre-commit
. unkey
is heavily adapted from the former and code
is attributed wherever possible. Thank you!
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
File details
Details for the file unkey-0.0.1.tar.gz
.
File metadata
- Download URL: unkey-0.0.1.tar.gz
- Upload date:
- Size: 6.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.2 importlib_metadata/4.6.3 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.0 CPython/3.9.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 9dfc15bbaf1648e127c72bbb6881f149ae936b627e64c7262b0d15ade40cce4f |
|
MD5 | 71b32704b6a98f0ee76d50c6b99e3712 |
|
BLAKE2b-256 | 371a597df3a528fff3828d1835286f5e25e7216fa2b0c63e34ed4e1cfaf5530e |
File details
Details for the file unkey-0.0.1-py2.py3-none-any.whl
.
File metadata
- Download URL: unkey-0.0.1-py2.py3-none-any.whl
- Upload date:
- Size: 6.2 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.2 importlib_metadata/4.6.3 pkginfo/1.7.1 requests/2.26.0 requests-toolbelt/0.9.1 tqdm/4.62.0 CPython/3.9.6
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 86be774fc7159449569b255a7f60a5e221e3a437815fb35c3a6af04232bc799e |
|
MD5 | a4624d1bbcb6101dfc7d94521110586f |
|
BLAKE2b-256 | 57312518cedb55f56b5b32236208f9f71ca5df9d948a9faedb647ea20a80779b |