This guide is dedicated to writing clean, Pythonic code that adheres to best practices and embraces the nuances of Python development. It underscores idiomatic usage, performance, and maintainability.
/// admonition | type: abstract Foundational Code Standards{:target="_blank"} provide the foundation, this guide extends them for Python. /// //: # (@formatter:on)
While Python's PEP 8 provides comprehensive formatting guidelines, our foundational formatting standards also apply. Key Python-specific considerations include:
- Indentation: Use 4 spaces per indentation level.
- Line Length: Limit lines to 79 characters (and docstrings/comments to 72).
- Imports: Group imports into standard library, third-party, and local application/library specific, separated by blank lines.
- Whitespace: Use whitespace sparingly inside parentheses, brackets, and braces.
Pythonic naming favors readability and conciseness:
- Classes: Use
CamelCase
for class names without underscores. - Functions and Variables: Use
snake_case
for function names, variables, and method names. - Constants: Define constants in
UPPER_SNAKE_CASE
. - Protected and Private: Use
_protected
and__private
naming conventions for non-public methods and variables.
Inline comments should be used sparingly and must be meaningful. Explain "why" rather than "what".
Follow PEP 257 for docstring conventions. Use triple double quotes and describe the function's effect as a command:
def feed_goat(goat, food):
"""
Feed a goat with the specified food.
Args:
goat (Goat): The goat to be fed.
food (str): The type of food.
Returns:
bool: True if feeding is successful, False otherwise.
"""
Error Handling Prefer explicit exception handling over silent failures. Catch specific exceptions whenever possible:
try:
# risky operation
except ValueError as e:
# specific error handling
except Exception as e:
# generic error handling
Use list comprehensions to create lists in a concise and readable manner:
squared = [x**2 for x in range(10)]
Embrace the Zen of Python (import this) as a guiding philosophy. Prioritize readability, simplicity, and the "Pythonic" way of accomplishing tasks.
Leverage generators to create iterators without storing the entire sequence in memory:
def goat_names():
for goat in goat_herd:
yield goat.name
- Algorithms
- algorithms - Minimal examples of data structures and algorithms.
- python-ds - A collection of data structure and algorithms for coding interviews.
- sortedcontainers - Fast and pure-Python implementation of sorted collections.
- thealgorithms - All Algorithms implemented in Python.
- Design Patterns
- pypattyrn - A simple yet effective library for implementing common design patterns.
- python-patterns - A collection of design patterns in Python.
- transitions - A lightweight, object-oriented finite state machine implementation.
- PyCharm - Commercial Python IDE by JetBrains.
- Visual Studio with PTVS
- Visual Studio Code with Python
- spyder - Open Source Python IDE.
- Black: The uncompromising Python code formatter that adheres to PEP 8 and improves code readability.
- Flake8: A tool that enforces PEP 8 style guide and helps catch common programming errors.
- MyPy: A static type checker for Python that supports gradual typing.
- Pytest: Utilize pytest for testing and coverage analysis.
- Sphinx - Python Documentation generator.: Use Sphinx for generating documentation from docstrings.
- Pylint: A source code analyzer that checks for errors in Python code.