wemake-python-styleguide

The strictest and most opinionated python linter ever!

Github stars Tracking Chart

wemake-python-styleguide

wemake.services
Supporters
Build Status
Coverage Status
Github Action
Python Version
wemake-python-styleguide


Welcome to the strictest and most opinionated python linter ever.

wemake-python-styleguide is actually a flake8
plugin with some other plugins as dependencies.

Quickstart

pip install wemake-python-styleguide

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

We highly recommend to also use:

  • flakehell for easy integration into a legacy codebase
  • nitpick for sharing and validating configuration across multiple projects

Running

flake8 your_module.py

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

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

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

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, 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. Enforce python3.6+ usage
  2. Significantly reduce complexity of your code and make it more maintainable
  3. Enforce "There should be one -- and preferably only one -- obvious way to do it" rule to coding and naming styles
  4. 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. Reformat code, since we believe that developers should do 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 to 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.

Main metrics

Overview
Name With Ownerwemake-services/wemake-python-styleguide
Primary LanguagePython
Program languagePython (Language Count: 4)
Platform
License:MIT License
所有者活动
Created At2018-03-09 21:04:25
Pushed At2025-07-28 19:56:08
Last Commit At2025-07-28 22:56:07
Release Count62
Last Release Name1.3.0 (Posted on 2025-07-13 09:22:24)
First Release Name0.0.2 (Posted on 2018-07-01 14:26:40)
用户参与
Stargazers Count2.8k
Watchers Count29
Fork Count404
Commits Count2.9k
Has Issues Enabled
Issues Count1152
Issue Open Count17
Pull Requests Count1999
Pull Requests Open Count0
Pull Requests Close Count343
项目设置
Has Wiki Enabled
Is Archived
Is Fork
Is Locked
Is Mirror
Is Private