Guaranteed this buckaroo will give a thorough code review. Photo by Ali Hajian on Unsplash

8 Things to Check in a Python Code Review

Code reviews are one of the most important activities in the daily workings of a software team. They are an opportunity for everyone to become familiar with the codebase. They help prevent siloing (one person becoming the only source of knowledge). And they are a great opportunity for beginning programmers to learn from more experienced programmers.

When I do a python code review, I’m looking for several things.

Here is a list of eight basic things I look for first.
This is assuming that the code was formatted (using black, yapf or something similar) and linted (it follows pep-8) before check-in.

1. Are there things that were left there from debugging or working out the code? Print and debug statements are surprisingly common.

2. Are there constants in the code that should be declared at the top instead?

3. Are the names of functions and variables well chosen?

4. Are there variables that are only used once (single use variables) that could be folded into the code instead?

5. Are the for and while loops written in a pythonic way? Could they be replaced by a list or dictionary comprehension? Keep in mind though that a list comprehension can easily get to the point where it is too complicated. In that case the for loop might be easier to understand.

6. Does code get repeated in different parts of a file, or even different parts over multiple files? If so, put that code into its own function and maybe even a separate file that can be called from multiple files.

7. Does the same data get passed around a lot? Maybe it would be better as an instance variable in a class.

8. Were parameters deleted in a function? Double check that those parameters weren’t important to other python functions or files. Do a search through the whole repo, or even through the whole codebase for that function.

These are basic things that can be examined without thinking too much about the code.

Beyond this there should be questions about the overall architecture of the code and how it fits into the project.

One book that I highly recommend reading is Refactoring by Martin Fowler. The code examples are in javascript, but the concepts are very useful for all languages.



Get the Medium app

A button that says 'Download on the App Store', and if clicked it will lead you to the iOS App store
A button that says 'Get it on, Google Play', and if clicked it will lead you to the Google Play store
Python Is Rad

Python Is Rad. I’m a software engineer with an addiction to building things with code.