Modernisation Python 3.11+

VérifiéSûr

Applique les motifs de modernisation Python 3.11+ comme les annotations de type PEP 585/604, match-case, l'opérateur morse et le type Self. À utiliser pour réviser du code existant ou écrire du nouveau code avec les idiomes modernes. Supporte l'analyse de fichiers ou l'explication de sujets spécifiques.

Spar Skills Guide Bot
DeveloppementIntermédiaire
15002/06/2026
Claude Code
#python#type-hints#modern-patterns#pytest

Recommandé pour

Notre avis

Applique les idiomes modernes Python 3.11+ incluant les annotations de type, l'opérateur morse, le match-case, le type Self et les motifs pytest-mock pour la révision, l'écriture et la refactorisation de code.

Points forts

  • Impose des pratiques Python à jour.
  • Fournit des exemples concrets avant/après.
  • Couvre les annotations de type, les tests et les frameworks CLI.
  • Réduit le code redondant avec une syntaxe moderne.

Limites

  • Nécessite un environnement Python 3.11+.
  • Peut ne pas s'appliquer aux bases de code héritées qui ne peuvent pas être mises à niveau.
  • Se concentre sur les motifs syntaxiques, pas sur la conception architecturale.
Quand l'utiliser

Utilisez-le lors de l'écriture de nouveau code Python, de la révision de pull requests pour des opportunités de modernisation, ou de la refactorisation de code Python hérité pour adopter les idiomes actuels.

Quand l'éviter

Ne l'utilisez pas pour des projets qui doivent rester compatibles avec des versions de Python inférieures à 3.11, ou lorsque l'équipe n'est pas familière avec les fonctionnalités modernes de Python.

Analyse de sécurité

Sûr
Score qualité90/100

The skill is purely advisory, providing guidance on Python code modernization. It only reads files and suggests changes without executing any commands or performing network operations. There is no risk of destructive or exfiltrating actions.

Aucun point d'attention détecté

Exemples

Modernize a specific file
Modernize the Python code in 'src/utils.py' using Python 3.11+ patterns.
Explain a modern pattern
Explain how to use the Self type (PEP 673) in Python with before/after examples.
Refactor legacy patterns
Refactor this code to use modern Python: from typing import List; names: List[str] = ['a', 'b']

name: modernpython description: Apply modern Python 3.11+ best practices with proper types, DRY, SRP, and framework patterns. Use when reviewing Python code for modernization opportunities, when writing new Python code to ensure modern patterns, or when refactoring legacy Python code to use current idioms. user-invocable: true argument-hint: "[file-paths-or-topic]"

Python Modernization Guide

The model applies modern Python 3.11+ patterns when writing or reviewing Python code.

Arguments

$ARGUMENTS

Instructions

If file paths provided:

  1. Read each file
  2. Identify legacy patterns
  3. Apply modern transformations from the reference guide
  4. Report changes made or recommended

If topic provided (e.g., "typing", "match-case"):

  1. Provide guidance on that specific topic
  2. Show before/after examples

If no arguments:

  1. Ask what code to review or what topic to explain

Quick Reference: Modern Patterns

Type Hints (PEP 585, 604)

# Legacy (NEVER use)
from typing import List, Dict, Optional, Union

# Modern (ALWAYS use)
items: list[str]
config: dict[str, int] | None
value: int | str

Walrus Operator (PEP 572)

# Legacy
data = fetch_data()
if data:
    process(data)

# Modern
if data := fetch_data():
    process(data)

Match-Case (PEP 634)

Use match-case when using elif. Use if/elif only for inequalities or boolean operators.

# Modern (for any elif pattern)
match status_code:
    case 200: return "OK"
    case 404: return "Not Found"
    case _: return "Unknown"

Self Type (PEP 673)

from typing import Self

class Builder:
    def add(self, x: int) -> Self:
        self.value += x
        return self

Exception Notes (PEP 678)

except FileNotFoundError as e:
    e.add_note(f"Attempted path: {path}")
    raise

StrEnum (Python 3.11+)

from enum import StrEnum

class Status(StrEnum):
    PENDING = "pending"
    RUNNING = "running"

TOML Support (Python 3.11+)

import tomllib
from pathlib import Path

config = tomllib.load(Path("pyproject.toml").open("rb"))

Testing Patterns

ALWAYS use pytest-mock, NEVER unittest.mock:

# Legacy (NEVER use)
from unittest.mock import Mock, patch

# Modern (ALWAYS use)
from pytest_mock import MockerFixture

def test_feature(mocker: MockerFixture) -> None:
    mock_func = mocker.patch('module.function', return_value=42)

Framework Patterns

Typer CLI

ALWAYS use Annotated syntax:

from typing import Annotated
import typer

@app.command()
def process(
    input_file: Annotated[Path, typer.Argument(help="Input file")],
    verbose: Annotated[bool, typer.Option("--verbose", "-v")] = False,
) -> None:
    """Process input file."""
    pass

Rich Tables

Use explicit width control for production CLIs:

from rich.console import Console
from rich.table import Table
from rich.measure import Measurement

def _get_table_width(table: Table) -> int:
    temp_console = Console(width=9999)
    measurement = Measurement.get(temp_console, temp_console.options, table)
    return int(measurement.maximum)

Detailed Reference

For complete transformation rules, PEP references, and framework patterns, see:

Complete Modernization Guide


Core Principles

  1. Use Python 3.11+ as minimum baseline
  2. Leverage built-in generics (PEP 585) and pipe unions (PEP 604) exclusively
  3. Apply walrus operator to reduce line count
  4. Use match-case for elif patterns
  5. Implement comprehensive type hints with Protocol, TypeVar, TypeGuard
  6. Use Self type (PEP 673) for fluent APIs
  7. Follow Typer patterns with Annotated syntax for CLIs
  8. Use Rich for terminal output with proper width handling
  9. Write pytest tests with pytest-mock and AAA pattern
  10. Apply clean architecture with dependency injection

References

Skills similaires