Skip to main content

The strictest and most opinionated python linter ever

Project description

wemake-python-styleguide

wemake.services Supporters test codecov Python Version wemake-python-styleguide


Welcome to the strictest and most opinionated Python linter ever.

wemake-python-styleguide logo

wemake-python-styleguide is actually a flake8 plugin, the only one you will need as your ruff companion.

Fully compatible with ALL rules and format conventions from ruff.

Quickstart

pip install wemake-python-styleguide

You will also need to create a setup.cfg file with the configuration.

Try it online!

We highly recommend to also use:

  • ondivi for easy integration into a legacy codebase

Running

flake8 your_module.py --select=WPS

This app is still just good old flake8! And it won't change your existing workflow.

invocation results

See "Usage" section in the docs for examples and integrations.

We also support GitHub Actions as first class-citizens. Try it out!

Can (and should!) be used with ruff:

ruff check && ruff format
flake8 . --select=WPS

See example ruff configuration in our pyproject.toml.

Strict is the new cool

Strict linting offers the following benefits to developers and companies:

  1. Ensures consistency - no matter who works on it, the end product will always be the same dependable code
  2. Helps avoid potential bugs - strict rules make sure that you don't make common mistakes
  3. Efficient code reviews - each piece of code has a similar familiar style and syntax. If it passes all the checks, there's little left to review!
  4. Fewer code revisions - strict linting ensures that you don't have to re-write the codebase again and again
  5. Reduce code redundancy - Sometimes we write complex code as we are thinking in a certain way about a problem. The linter offers suggestions that can help simplify the code and eliminate redundant statements

What we are about

The ultimate goal of this project is to make all people write exactly the same Python code.

flake8 pylint black mypy ruff wemake-python-styleguide
Formats code?
Finds style issues? 🤔 🤔
Finds bugs? 🤔
Finds complex code? 🤔
Has a lot of strict rules? 🤔
Has a lot of plugins? 🤔 🤔

We have several primary objectives:

  1. Significantly reduce the complexity of your code and make it more maintainable
  2. Enforce "There should be one -- and preferably only one -- obvious way to do it" rule to coding and naming styles
  3. Protect developers from possible errors and enforce best practices

You can find all error codes and plugins in the docs.

What we are not

We are not planning to do the following things:

  1. Assume or check types, use mypy together with our linter
  2. Format code or produce stylistic errors, use ruff format for that
  3. Check for SyntaxError or logical bugs, write tests instead
  4. Appeal to everyone. But, you can switch off any rules that you don't like

Supporting us :tada:

We in wemake.services make all our tools open-source by default, so the community can benefit from them. If you use our tools and they make your life easier and brings business value, you can return us a favor by supporting the work we do.

Gold Tier

Silver Tier

Bronze Tier

Show your style :sunglasses:

If you use our linter - it means that your code is awesome. You can be proud of it! And you should share your accomplishment with others by including a badge in your README file. It looks like this:

wemake-python-styleguide

Markdown

[![wemake-python-styleguide](https://img.shields.io/badge/style-wemake-000000.svg)](https://github.com/wemake-services/wemake-python-styleguide)

Restructured text

.. image:: https://img.shields.io/badge/style-wemake-000000.svg
   :target: https://github.com/wemake-services/wemake-python-styleguide

Contributing

We warmly welcome all contributions!

List of contributors

See "Contributing" section in the documentation if you want to contribute.

You can start with issues that need some help right now.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

wemake_python_styleguide-1.5.0.tar.gz (156.8 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

wemake_python_styleguide-1.5.0-py3-none-any.whl (220.0 kB view details)

Uploaded Python 3

File details

Details for the file wemake_python_styleguide-1.5.0.tar.gz.

File metadata

  • Download URL: wemake_python_styleguide-1.5.0.tar.gz
  • Upload date:
  • Size: 156.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/2.2.1 CPython/3.11.9 Darwin/24.6.0

File hashes

Hashes for wemake_python_styleguide-1.5.0.tar.gz
Algorithm Hash digest
SHA256 a764b30bd298ecd3ca9d5cd64b7776dec9a529d728291e8b8076a56649d6cce1
MD5 7bc57da899bbbe6792e8f4819f40a38e
BLAKE2b-256 0a06a0968903b6d41de7c41b8d8cc6a31471894365fe0c7b13684a3e6faa956d

See more details on using hashes here.

File details

Details for the file wemake_python_styleguide-1.5.0-py3-none-any.whl.

File metadata

File hashes

Hashes for wemake_python_styleguide-1.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0743a8d1a748e3b84cad5804de4e6211641cd77e5ea0e4aaeec1993765e7f6c0
MD5 d290c143ac1b09ff333a92dcb7d10013
BLAKE2b-256 152a9e303a946df30335695b60c0f75dc49a5f339cf4a101772522c88d4133f7

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page