Need help with nbQA?
Click the “chat” button below for chat support from the developer who created it, or find similar developers for support.

About the developer

312 Stars 20 Forks MIT License 564 Commits 5 Opened issues


Run isort, pyupgrade, mypy, pylint, flake8, and more on Jupyter Notebooks

Services available


Need anything else?

Contributors list


Run isort, pyupgrade, mypy, pylint, flake8, and more on Jupyter Notebooks

tox codecov pre-commit

versions chat docs



  • ✅ handles IPython magics robustly
  • ✅ respects your config files
  • ✅ preserves "quiet mode" trailing semicolons

Table of contents

🎉 Installation

In your virtual environment, run one of the following:

  • python -m pip install -U nbqa
  • conda install -c conda-forge nbqa

🚀 Examples


Here's an example of how to set up some pre-commit hooks: put this in your

file (see usage as pre-commit hook)
- repo:
  rev: 1.1.1
    - id: nbqa-black
    - id: nbqa-pyupgrade
      args: [--py36-plus]
    - id: nbqa-isort

If you need to select specific versions of any of these linters/formatters, add them to



Reformat your notebooks with black:

$ nbqa black my_notebook.ipynb
reformatted my_notebook.ipynb
All done! ✨ 🍰 ✨
1 files reformatted.

Sort your imports with isort:

$ nbqa isort my_notebook.ipynb
Fixing my_notebook.ipynb

Upgrade your syntax with pyupgrade:

$ nbqa pyupgrade my_notebook.ipynb --py36-plus
Rewriting my_notebook.ipynb

See command-line examples for examples involving doctest, flake8, mypy, pylint, autopep8, pydocstyle, and yapf.

🥳 Used by

Click here for (non-exhaustive) list of repos

Is your project missing? Let us know, or open a pull request!

💬 Testimonials

Michael Kennedy & Brian Okken, hosts of the Python Bytes podcast:

This is really cool. I think it brings so much of the code formatting and code analysis, clean up to notebooks, which I think had been really lacking

Nikita Sobolev, CTO at

It is amazing!

Alex Andorra, Data Scientist, ArviZ & PyMC Dev, Host of 'Learning Bayesian Statistics' Podcast:

well done on

@MarcoGorelli ! Will be super useful in CI

Matthew Feickert, Postdoc at University of Illinois working on LHC physics:

nbqa in your pre-commit hooks along with @codewithanthony 's pre-commit CI service is amazing! Everyone using Jupyter notebooks should be doing this.

Girish Pasupathy, Software engineer and now core-contributor:

thanks a lot for your effort to create such a useful tool

Simon Brugman, Data scientist & pandas-profiling dev:

nbQA helps us to keep notebooks to the same standards as the rest of the code. If you're serious about your code standards, you should keep them consistent across both notebooks and python scripts. Great addition to the ecosystem, thanks!

Bradley Dice, PhD Candidate in Physics & Scientific Computing:

nbqa is a clean, easy to use, and effective tool for notebook code style. Formatting and readability makes a huge difference when rendering notebooks in a project's documentation!

James Lamb, engineer @saturn_cloud, LightGBM maintainer

today I learned about

, a command-line tool to run linters like
over #Python code in @ProjectJupyter notebooks. Thanks to @jayyqi for pointing me to it. So far, I really really like it.

Lars Yencken, Tech Lead @ Our World In Data

Super useful! I only wish it was built-in to Jupyterlab.

👥 Contributing

I will give write-access to anyone who makes a useful pull request - see the contributing guide for details on how to do so.

Thanks goes to these wonderful people (emoji key):

Marco Gorelli

💻 🚧 👀 ⚠️ 🤔

Sebastian Weigand

🔧 👀 📖 🤔

Girish Pasupathy

💻 🚇 🐛 👀 🤔






🤔 🚇

Daniel Mietchen


Michał Gacka




Nat Taylor

🤔 💻 🔧 🐛

Caio Ariede


Nikita Sobolev

🤔 🐛 📖

Amichay Oren




Henry Schreiner


Kaiqi Dong


Simon Brugman


John Sandall


Nathan Cooper




Rafal Wojdyla


Bradley Dice

🤔 💻

Ivan Cheung


Tony Hirst


Taneli Hukkinen


Tom Begley

🤔 💻 📖

Steven DeMartini


This project follows the all-contributors specification. Contributions of any kind welcome!

We use cookies. If you continue to browse the site, you agree to the use of cookies. For more information on our use of cookies please see our Privacy Policy.