You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Pylint is a static code analyser for Python 2 or 3. The latest version supports Python
3.10.0 and above.
Pylint analyses your code without actually running it. It checks for errors, enforces a
coding standard, looks for code smells, and can make suggestions about how the code
could be refactored.
It can also be integrated in most editors or IDEs. More information can be found
in the documentation.
What differentiates Pylint?
Pylint is not trusting your typing and is inferring the actual values of nodes (for a
start because there was no typing when pylint started off) using its internal code
representation (astroid). If your code is import logging as argparse, Pylint
can check and know that argparse.error(...) is in fact a logging call and not an
argparse call. This makes pylint slower, but it also lets pylint find more issues if
your code is not fully typed.
[inference] is the killer feature that keeps us using [pylint] in our project despite how painfully slow it is.
- Realist pylint user, 2022
pylint, not afraid of being a little slower than it already is, is also a lot more thorough than other linters.
There are more checks, including some opinionated ones that are deactivated by default
but can be enabled using configuration.
How to use pylint
Pylint isn't smarter than you: it may warn you about things that you have
conscientiously done or check for some things that you don't care about.
During adoption, especially in a legacy project where pylint was never enforced,
it's best to start with the --errors-only flag, then disable
convention and refactor messages with --disable=C,R and progressively
re-evaluate and re-enable messages as your priorities evolve.
Pylint is highly configurable and permits to write plugins in order to add your
own checks (for example, for internal libraries or an internal rule). Pylint also has an
ecosystem of existing plugins for popular frameworks and third-party libraries.
Note
Pylint supports the Python standard library out of the box. Third-party
libraries are not always supported, so a plugin might be needed. A good place
to start is PyPI which often returns a plugin by searching for
pylint <library>. pylint-pydantic, pylint-django and
pylint-sonarjson are examples of such plugins. More information about plugins
and how to load them can be found at plugins.
Advised linters alongside pylint
Projects that you might want to use alongside pylint include ruff (really fast,
with builtin auto-fix and a large number of checks taken from popular linters, but
implemented in rust) or flake8 (a framework to implement your own checks in python using ast directly),
mypy, pyright / pylance or pyre (typing checks), bandit (security oriented checks), black and
isort (auto-formatting), autoflake (automated removal of unused imports or variables), pyupgrade
(automated upgrade to newer python syntax) and pydocstringformatter (automated pep257).
Additional tools included in pylint
Pylint ships with two additional tools:
pyreverse (standalone tool that generates package and class diagrams.)
symilar (duplicate code finder that is also integrated in pylint)
Contributing
We welcome all forms of contributions such as updates for documentation, new code, checking issues for duplicates or telling us
that we can close them, confirming that issues still exist, creating issues because
you found a bug or want a feature, etc. Everything is much appreciated!
Professional support for pylint is available as part of the Tidelift
Subscription. Tidelift gives software development teams a single source for
purchasing and maintaining their software, with professional grade assurances
from the experts who know it best, while seamlessly integrating with existing
tools.