Agent skill
python
Python development guidelines and best practices. Use when working with Python code.
Install this agent skill to your Project
npx add-skill https://github.com/siviter-xyz/dot-agent/tree/main/skills/python
SKILL.md
Python Guidelines
Standards and best practices for Python development. Follow these guidelines when writing or modifying Python code.
Design Principles
Apply DRY, KISS, and SOLID consistently. Prefer functional methods where relevant; use classes for stateful behavior. Use composition with Protocol classes for interfaces rather than inheritance. Each module should have a single responsibility. Use dependency injection for class dependencies.
Code Style
- Naming: Descriptive yet concise names for variables, methods, and classes
- Documentation: Docstrings for all classes, functions, enums, enum values
- Type hints: Use consistently; avoid
Anyunless necessary - Imports: Avoid barrel exports in
__init__.py; prefer blank files
Type Annotations
- Use
dict,listinstead oftyping.Dict,typing.List - Use
str | Noneinstead ofOptional[str] - Include
from __future__ import annotationsat top of files with type hints - Prefer built-in types over typing module equivalents
Architecture
Dependency Injection
- Always inject dependencies via constructors or methods when using classes
- One service class per module (interface and class models allowed in addition)
- Use Protocol classes to define interfaces for dependency injection and testing
Module Organization
- Each module focuses on one concern with clear boundaries
- Extract reusable methods to avoid duplication
- Design for reusability across contexts
Environment Variables
- Use an
environment.pyfile with individual methods per variable (e.g.,api_key()forAPI_KEY,database_url()forDATABASE_URL) - Co-locate all environment access in one place per package for easier mocking in tests
Data Models
- Use Pydantic v2 for schemas, validation, and data models
- Leverage Pydantic's type validation, serialization, and configuration management
- Use Pydantic models for API request/response schemas, configuration objects, and data transfer objects
Testing
Structure
- Tests mirror
src/directory structure - Test methods start with
test_ - Use test class suites: for
def foo()createclass TestFoo - Keep names concise, omit class suite name from method
- Always check for appropriate unit tests when changing code
Quality
- Use AAA (Arrange, Act, Assert) pattern
- Tests should be useful, readable, concise, maintainable
- Avoid tests that create massive diffs or become burdensome
Tools
- Prefer
pytestoverunittest - Use
pytest-mockfor mocking - Use
conftest.pyfor shared fixtures - Use
tests/__test_<package_name>__for shared testing code
Implementation
When implementing Python code:
- Ensure code passes type checking and tests before committing
- Group related changes with tests in atomic commits
- Check for existing workflow patterns (spec-first, TDD, etc.) and follow them
References
- For adhoc Python scripts in uv-managed projects, see
references/uv-scripts.md. - For monorepo-specific patterns using uv and Hatch, see
references/uv-monorepo.md.
Recommended Agent Skills
Expand your agent's capabilities with these related and highly-rated skills.
frontend-engineer
Frontend development guidelines for React/TypeScript applications. Modern patterns including Suspense, lazy loading, useSuspenseQuery, file organization with features directory, MUI v7 styling, TanStack Router, performance optimization, and TypeScript best practices. Use when creating components, pages, features, fetching data, styling, routing, or working with frontend code.
debugging
Root cause analysis and debugging protocols. Use when encountering errors, test failures, unexpected behavior, stack traces, or when code behaves differently than expected.
code-review
Code review practices emphasizing technical rigor, evidence-based claims, and verification. Use when receiving code review feedback, completing tasks requiring review, or before making completion claims.
cursor-best-practices
Best practices for working with Cursor. Use when learning how to effectively use Cursor features or optimizing your workflow.
create-skill
Guide for creating effective skills following best practices. Use when creating or updating skills that extend agent capabilities.
semantic-git
Manage Git commits using conventional commit format with atomic staging. Always generate plain git commands before running them and offer to let the user run them manually.
Didn't find tool you were looking for?