Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/adamchainz/flake8-tidy-imports
❄️ A flake8 plugin that helps you write tidier imports.
https://github.com/adamchainz/flake8-tidy-imports
flake8
Last synced: 2 months ago
JSON representation
❄️ A flake8 plugin that helps you write tidier imports.
- Host: GitHub
- URL: https://github.com/adamchainz/flake8-tidy-imports
- Owner: adamchainz
- License: mit
- Created: 2016-01-22T15:40:39.000Z (almost 9 years ago)
- Default Branch: main
- Last Pushed: 2024-04-29T21:02:45.000Z (9 months ago)
- Last Synced: 2024-05-01T12:53:41.579Z (9 months ago)
- Topics: flake8
- Language: Python
- Homepage:
- Size: 595 KB
- Stars: 66
- Watchers: 4
- Forks: 14
- Open Issues: 5
-
Metadata Files:
- Readme: README.rst
- Changelog: CHANGELOG.rst
- License: LICENSE
- Code of conduct: .github/CODE_OF_CONDUCT.md
- Security: .github/SECURITY.md
Awesome Lists containing this project
- awesome-flake8-extensions - flake8-tidy-imports - Extension that helps you write tidier imports. (Imports)
README
===================
flake8-tidy-imports
===================.. image:: https://img.shields.io/github/actions/workflow/status/adamchainz/flake8-tidy-imports/main.yml.svg?branch=main&style=for-the-badge
:target: https://github.com/adamchainz/flake8-tidy-imports/actions?workflow=CI.. image:: https://img.shields.io/pypi/v/flake8-tidy-imports.svg?style=for-the-badge
:target: https://pypi.org/project/flake8-tidy-imports/.. image:: https://img.shields.io/badge/code%20style-black-000000.svg?style=for-the-badge
:target: https://github.com/psf/black.. image:: https://img.shields.io/badge/pre--commit-enabled-brightgreen?logo=pre-commit&logoColor=white&style=for-the-badge
:target: https://github.com/pre-commit/pre-commit
:alt: pre-commitA `flake8 `_ plugin that helps you write tidier imports.
----
**Linting a Django project?**
Check out my book `Boost Your Django DX `__ which covers Flake8 and many other code quality tools.----
Requirements
============Python 3.9 to 3.13 supported.
Installation
============First, install with ``pip``:
.. code-block:: sh
python -m pip install flake8-tidy-imports
Second, if you define Flake8’s ``select`` setting, add the ``I25`` prefix to it.
Otherwise, the plugin should be active by default.Options
=======``banned-modules``
------------------Config for rule I251 (below).
Should contain a map where each line is a banned import string, followed by '=', then the message to use when encountering that import.There is also a special directive to ban a preselected list of removed/moved modules between Python 2 and Python 3, recommending replacements from `six
`_ where possible.
It can be turned on by adding ``{python2to3}`` to the list of ``banned-modules``.For example in ``setup.cfg``:
.. code-block:: ini
[flake8]
banned-modules =
mock = Use unittest.mock.
{python2to3}Note that despite the name, you can ban imported objects too, since the syntax is the same.
For example:.. code-block:: ini
[flake8]
banned-modules =
decimal.Decimal = Use ints and floats only.Entries containing ``*`` are treated as wildcards matching zero or more path components.
For example:* ``example.yellow.*`` matches ``example.yellow``, ``example.yellow.truck``, ``example.yellow.truck.driving`` etc.
* ``example.*.truck`` matches ``example.truck``, ``example.yellow.truck``, ``example.red.truck``, ``example.big.red.truck``, etc.``ban-relative-imports``
------------------------Controls rule I252 (below). Accepts two values:
* ``parents`` - bans imports from parent modules (and grandparents, etc.), i.e. with more than one ``.``.
* ``true`` - bans all relative imports.For example:
.. code-block:: ini
[flake8]
ban-relative-imports = parents(If you want to ban absolute imports, you can put your project's modules in ``banned-modules``.)
Rules
=====**Note:** Before version 4.0.0, the rule codes were numbered 50 lower, e.g. I250 was I200.
They were changed in `Issue #106 `__ due to conflict with ``flake8-import-order``.I250: Unnecessary import alias
------------------------------Complains about unnecessary import aliasing of three forms:
* ``import foo as foo`` -> ``import foo``
* ``import foo.bar as bar`` -> ``from foo import bar``
* ``from foo import bar as bar`` -> ``from foo import bar``The message includes the suggested rewrite (which may not *always* be correct), for example:
.. code-block:: sh
$ flake8 file.py
file.py:1:1: I250 Unnecessary import alias - rewrite as 'from foo import bar'.Such aliases can be automatically fixed by ``isort`` if you activate its `remove_redundant_aliases option `__.
I251: Banned import ```` used.
--------------------------------------Complains about use of banned imports.
By default there are no imports banned - you should configure them with ``banned-modules`` as described above in 'Options'.The message includes a user-defined part that comes from the configuration.
For example:.. code-block:: sh
$ flake8 file.py
file.py:1:1: I251 Banned import 'mock' used - use unittest.mock instead.I252: Relative imports are banned.
--------------------------------------------------------Complains about use of relative imports:
* ``from . import foo`` (sibling import)
* ``from .bar import foo`` (sibling import)
* ``from .. import foo`` (parent import)Controlled by the ``ban-relative-imports`` configuration option.
Absolute imports, or relative imports from siblings, are recommended by `PEP8 `__:
Absolute imports are recommended, as they are usually more readable and tend to be better behaved...
.. code-block:: python
import mypkg.sibling
from mypkg import sibling
from mypkg.sibling import exampleHowever, explicit relative imports are an acceptable alternative to absolute imports...
.. code-block:: python
from . import sibling
from .sibling import exampleSee also
--------For more advanced control of imports in your project, try `import-linter `__.