uv-expert
UV Expert
Expert guidance for uv, the extremely fast Python package and project manager written in Rust. UV provides a unified interface for Python dependency management, project creation, virtual environments, and more.
Additional Resources
For detailed API documentation and configuration options, see the UV Source Documentation which includes:
- Command Line Reference - Complete CLI command documentation
- Configuration Settings - All configuration options
- Environment Variables - Environment variable references
- Installation Guide - Detailed installation instructions
For performance benchmarks and technical details, refer to BENCHMARKS.md in the source code.
For troubleshooting common issues, see the Troubleshooting Guide.
The complete source code and implementation details are available at source/uv/.
Instructions
Core UV Concepts
UV is a comprehensive Python tool that replaces:
pip(package installation)pip-tools(dependency resolution)pipx(tool installation)poetry(project management)pyenv(Python version management)virtualenv(virtual environments)twine(package publishing)
Installation
Recommended installation methods:
# Standalone installer (macOS/Linux)
curl -LsSf https://astral.sh/uv/install.sh | sh
# Windows PowerShell
powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"
# Via pip
pip install uv
# Via pipx
pipx install uv
Project Management
Initialize new projects:
# Create new project
uv init my-project
cd my-project
# Create with specific Python version
uv init my-project --python 3.11
# Create from existing directory
uv init
Dependency management:
# Add dependencies
uv add requests pandas
# Add development dependencies
uv add --dev pytest black
# Add with specific version
uv add "requests>=2.28.0"
# Remove dependencies
uv remove requests
# Update dependencies
uv lock --upgrade
Project execution:
# Run commands in project environment
uv run python main.py
uv run pytest
uv run black .
# Run scripts
uv run script.py
Virtual Environments
Environment management:
# Create virtual environment
uv venv
# Create with specific Python version
uv venv --python 3.11
# Activate environment (standard approach)
source .venv/bin/activate # Unix
.venv\Scripts\activate # Windows
# Use environment without activation
uv pip install requests
uv python script.py
Package Installation
** pip-compatible interface:**
# Install packages
uv pip install requests pandas
# Install from requirements
uv pip install -r requirements.txt
# Install with constraints
uv pip install -c constraints.txt
# Install in editable mode
uv pip install -e .
# Uninstall packages
uv pip uninstall requests
Python Version Management
Python version management:
# List available Python versions
uv python list
# Install Python version
uv python install 3.11
# Set Python version for project
uv python pin 3.11
# Use specific Python version
uv run --python 3.11 script.py
Tool Management
Install and manage tools:
# Install as tool
uv tool install ruff
uv tool install pytest
# Run tools
uv run ruff check .
uv run pytest
# List installed tools
uv tool list
# Uninstall tools
uv tool uninstall ruff
Scripts Support
Run scripts with inline dependencies:
# script.py with inline dependencies
# /// script
# requires-python = ">=3.8"
# dependencies = [
# "requests",
# "typer",
# ]
# ///
import requests
import typer
def main():
response = requests.get("https://api.github.com")
print(f"Status: {response.status_code}")
if __name__ == "__main__":
typer.run(main)
# Run script with automatic dependency resolution
uv run script.py
Advanced Features
Workspaces:
# Create workspace
# pyproject.toml
[tool.uv.workspace]
members = ["packages/*"]
# Work with workspace
uv add requests --workspace
uv sync --workspace
Caching:
# Clear cache
uv cache clean
# View cache info
uv cache info
# Warm cache
uv sync --cache-dir ~/.cache/uv
Configuration:
# Set global configuration
uv config set global.cache-dir ~/.cache/uv
# View configuration
uv config show
# Use configuration file
# ~/.config/uv/uv.toml
[global]
cache-dir = "~/.cache/uv"
index-url = "https://pypi.org/simple"
Common Workflows
1. Set up new project:
uv init my-project
cd my-project
uv add requests pytest --dev
uv run pytest
2. Work on existing project:
git clone <repo>
cd <repo>
uv sync
uv run python main.py
3. Migrate from pip:
# Replace pip install
uv pip install package
# Replace requirements.txt workflow
uv add package # Adds to pyproject.toml
uv lock # Creates lockfile
4. CI/CD integration:
# Install dependencies
uv sync
# Run tests
uv run pytest
# Build package
uv build
Performance Benefits
UV is 10-100x faster than pip:
- Parallel downloads and installations
- Efficient caching
- Rust-based performance
- Global dependency deduplication
Use UV when you need:
- Faster dependency resolution
- Unified Python toolchain
- Modern Python project management
- Better caching and performance
- Cross-platform consistency
Migration Guides
From pip:
- Replace
pip installwithuv add(for projects) oruv pip install(standalone) - Replace
pip freezewithuv pip freezeor useuv.lock - Replace
venvwithuv venv
From poetry:
pyproject.tomlformat is compatible- Replace
poetry addwithuv add - Replace
poetry installwithuv sync - Replace
poetry runwithuv run
From conda:
- Use UV for Python packages, conda for system packages
- Migrate environment.yml to pyproject.toml
- Use
uv venvinstead of conda environments
Best Practices
1. Project Structure:
my-project/
├── pyproject.toml
├── uv.lock
├── src/
└── tests/
2. Dependency Management:
- Use
uv addfor project dependencies - Use
uv add --devfor development dependencies - Keep
uv.lockin version control - Use
uv syncto reproduce environments
3. Virtual Environments:
- Always use virtual environments
- Use
uv runinstead of manual activation - Delete
.venvwhen switching Python versions
4. Performance:
- Let UV manage the cache automatically
- Use workspaces for multi-package projects
- Enable parallel operations where possible
Troubleshooting
Common issues:
- Cache corruption: Run
uv cache clean - Python version conflicts: Use
uv python pin - Network issues: Check
uv config get index-url - Permission errors: Use user installations or virtual environments
Debug mode:
# Enable verbose output
uv --verbose sync
# Show resolution details
uv add package --verbose
Integration Examples
With Docker:
FROM python:3.11-slim
COPY uv.lock pyproject.toml ./
RUN pip install uv && uv sync
COPY . .
CMD ["uv", "run", "python", "main.py"]
With GitHub Actions:
- name: Install uv
uses: astral-sh/setup-uv@v1
- name: Install dependencies
run: uv sync
- name: Run tests
run: uv run pytest
Resources
- Official documentation: https://docs.astral.sh/uv/
- GitHub repository: https://github.com/astral-sh/uv
- Benchmark comparisons: See BENCHMARKS.md in source
- Community Discord: https://discord.gg/astral-sh
More from straydragon/my-claude-skills
rust-cli-tui-developer
Expert guidance for Rust CLI and TUI development with official examples from clap, inquire, and ratatui libraries. Use when building command-line interfaces, terminal user interfaces, or console applications in Rust. Provides structured patterns, best practices, and real code implementations from official sources.
11feishu-openapi-dev
Expert guidance for Feishu (飞书) / Lark OpenAPI Python development. Build Feishu applications, robots, handle event subscriptions, card callbacks, and API integrations. Use when working with Feishu SDK, lark-oapi, building Feishu bots, or mentioning 飞书 development.
10lib-slint-expert
Comprehensive Slint GUI development expert based on official source code. Covers Rust integration, component design, layouts, styling, animations, cross-platform deployment, and performance optimization. Use when working with Slint UI toolkit, building native GUI applications, or when mentioning Slint, GUI development, or Rust user interfaces. Built with official documentation and examples.
7mermaid-expert
Expert guidance for Mermaid.js diagramming library. Create flowcharts, sequence diagrams, class diagrams, state diagrams, Gantt charts, git graphs, and block diagrams. Use when working with Mermaid syntax, creating diagrams, or visualizing complex concepts and workflows.
4agent-skills-expert
Expert for creating and managing Claude Code Agent Skills. Create skills with git submodule + sparse-checkout for source references, write SKILL.md with proper frontmatter, and follow best practices. Use when creating new skills, adding source references to skills, or managing skill configurations.
4ui-ux-pro-max
UI/UX design intelligence. 50 styles, 21 palettes, 50 font pairings, 20 charts, 8 stacks (React, Next.js, Vue, Svelte, SwiftUI, React Native, Flutter, Tailwind). Actions: plan, build, create, design, implement, review, fix, improve, optimize, enhance, refactor, check UI/UX code. Projects: website, landing page, dashboard, admin panel, e-commerce, SaaS, portfolio, blog, mobile app, .html, .tsx, .vue, .svelte. Elements: button, modal, navbar, sidebar, card, table, form, chart. Styles: glassmorphism, claymorphism, minimalism, brutalism, neumorphism, bento grid, dark mode, responsive, skeuomorphism, flat design. Topics: color palette, accessibility, animation, layout, typography, font pairing, spacing, hover, shadow, gradient.
3