Awesome-omni-skill python-core

Create, write, build, debug, test, refactor, and optimize Python 3.10+ applications across all domains (data science, backend APIs, scripting, automation). Manage dependencies with uv (preferred), poetry, or pip. Implement type hints (typing module, generics, protocols), write tests with pytest (fixtures, parametrize, mocking), work with pandas DataFrames (creation, selection, groupby, merge), use dataclasses and decorators, handle errors with logging integration, and follow TDD workflows (Red-Green-Refactor). Configure virtual environments, pyproject.toml, and static analysis tools (mypy, pyright). Use when implementing Python features, fixing bugs, writing tests, managing packages, analyzing data, or building Python projects.

install
source · Clone the upstream repo
git clone https://github.com/diegosouzapw/awesome-omni-skill
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/diegosouzapw/awesome-omni-skill "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/development/python-core" ~/.claude/skills/diegosouzapw-awesome-omni-skill-python-core && rm -rf "$T"
manifest: skills/development/python-core/SKILL.md
source content

Quick Start

Prerequisites:

  • Python 3.10+ installed (
    python --version
    )
  • Dependency manager: uv (recommended), poetry, or pip+venv
  • IDE with Python language server (VS Code, PyCharm)

Tools Used: Read, Write, Edit, Bash (for uv/poetry/pip commands), LSP diagnostics

Dependency Management Decision Tree:

New project? → Use uv: uv init, uv add, uv sync
Existing poetry? → Use poetry: poetry install, poetry add
Legacy/simple? → Use pip+venv: python -m venv, pip install

Basic Usage:

  1. Set up environment (see decision tree)
  2. Write code with type hints
  3. Write tests first (TDD)
  4. Run tests:
    pytest
  5. Verify types:
    mypy .

What I Do

  • Create Python 3.10+ applications (data science, backend, scripting, automation)
  • Manage dependencies with uv, poetry, or pip
  • Implement type hints (typing module, generics, protocols)
  • Write tests with pytest (fixtures, parametrize, mocking)
  • Work with pandas DataFrames (selection, groupby, merge)
  • Use Python patterns (decorators, comprehensions, generators, dataclasses)
  • Handle errors with logging integration
  • Follow TDD workflow (Red-Green-Refactor)

When to Use Me

Use this skill when you:

  • Create, refactor, or debug Python 3.10+ code
  • Set up projects with dependency management (uv, poetry, pip)
  • Implement type hints or fix type errors
  • Write pytest tests (fixtures, parametrize, mocking)
  • Work with pandas DataFrames
  • Use Python patterns (decorators, generators, dataclasses)
  • Handle errors with logging
  • Follow TDD workflows

Python Version Features

VersionFeatures
3.10Pattern matching, union types (
|
),
TypeAlias
3.11Exception groups (
except*
),
Self
type
3.12Type parameters (
def func[T]
), f-string improvements

Quick Reference Tables

Built-in Functions

FunctionPurpose
map(func, iterable)
Apply function to each item
filter(func, iterable)
Keep items where condition is True
zip(*iterables)
Combine iterables element-wise
enumerate(iterable)
Add index to iterable

String Operations

OperationExample
f-strings
f"Hello {name}"
.join()
", ".join(['a', 'b'])
.split()
"a,b".split(",")

Collection Methods

TypeCommon Methods
list
.append()
,
.extend()
,
.pop()
,
.sort()
dict
.get()
,
.keys()
,
.values()
,
.items()
set
.add()
,
.remove()
,
.union()

Type Hints Basics

from typing import Optional

def greet(name: str) -> str:
    return f"Hello {name}"

def process_items(items: list[int]) -> dict[str, int]:
    return {"count": len(items), "sum": sum(items)}

def find_user(user_id: int) -> Optional[str]:
    return users.get(user_id)

def parse_value(val: str | int) -> int:  # Python 3.10+
    return int(val)

See references/type-hints.md for Generics and Protocols.

TDD Workflow (Red-Green-Refactor)

  1. Red: Write failing test
  2. Green: Write minimal code to pass
  3. Refactor: Improve while keeping tests green
# Red: Test fails (function doesn't exist)
def test_total():
    assert calculate_total([10, 20, 30]) == 60

# Green: Make it pass
def calculate_total(items):
    return sum(items)

# Refactor: Add types and edge cases
def calculate_total(items: list[int]) -> int:
    return sum(items) if items else 0

See references/pytest.md for fixtures and mocking.

Error Handling with Logging

import logging

logger = logging.getLogger(__name__)

# Try/Except/Finally
try:
    result = risky_operation()
except ValueError as e:
    logger.error(f"Invalid value: {e}")
    raise
finally:
    cleanup_resources()

# Custom Exceptions
class DataValidationError(Exception):
    pass

def validate_data(data: dict) -> None:
    if "required_field" not in data:
        raise DataValidationError("required_field missing")

# Context Manager for cleanup
from contextlib import contextmanager

@contextmanager
def db_connection(url: str):
    conn = connect(url)
    try:
        yield conn
    finally:
        conn.close()

Examples

Example 1: Dataclass with Type Hints

from dataclasses import dataclass
from typing import List, Optional

@dataclass
class User:
    id: int
    name: str
    email: str
    tags: List[str] = None
    
    def __post_init__(self):
        if self.tags is None:
            self.tags = []

# Usage
user = User(id=1, name="Alice", email="alice@example.com")
user.tags.append("admin")

Example 2: Decorator Pattern

import functools
import time
import logging

logger = logging.getLogger(__name__)

def timing_decorator(func):
    @functools.wraps(func)
    def wrapper(*args, **kwargs):
        start = time.time()
        result = func(*args, **kwargs)
        elapsed = time.time() - start
        logger.info(f"{func.__name__} took {elapsed:.2f}s")
        return result
    return wrapper

@timing_decorator
def slow_function():
    time.sleep(1)
    return "done"

Example 3: List Comprehension with Filtering

# Filter and transform in one line
numbers = [1, 2, 3, 4, 5, 6]
even_squares = [x**2 for x in numbers if x % 2 == 0]
# Result: [4, 16, 36]

# Dict comprehension
users = [("alice", 25), ("bob", 30)]
user_dict = {name: age for name, age in users}
# Result: {"alice": 25, "bob": 30}

Example 4: Generator for Memory Efficiency

def read_large_file(file_path: str):
    with open(file_path, 'r') as f:
        for line in f:
            yield line.strip()

for line in read_large_file("huge.txt"):
    process(line)

See references/patterns.md for more patterns.

Common Errors

ErrorSolution
ModuleNotFoundError
Run
uv add <package>
or
pip install <package>
TypeError
Check types, add type hints
KeyError
Use
.get('key', default)
instead of
['key']
IndentationError
Use 4 spaces (PEP 8)
AttributeError: 'NoneType'
Check for None:
if obj is not None:

Related Skills

  • pytest-testing: Fixtures, parametrize, mocking
  • pandas-data-analysis: Advanced DataFrame operations
  • fastapi-backend: REST APIs with FastAPI
  • django-web: Web applications with Django
  • github-actions: CI/CD for Python

References