uv pip sync synchronizes a Python environment to exactly match a requirements file or lockfile. Unlike uv pip install, it removes packages that aren’t in the file.
Usage
Arguments
Input Files
Files to sync from.Supported formats:
requirements.txt.pyfiles with inline metadatapylock.tomlpyproject.toml,setup.py,setup.cfg
- to read from stdin.Constraints
Constrain package versions during sync.Environment:
UV_CONSTRAINTConstrain build dependencies when building from source.Environment:
UV_BUILD_CONSTRAINTOptional Dependencies
Include optional dependencies (extras) from
pylock.toml or pyproject.toml.--all-extras
Include all optional dependencies.
Install dependency groups from
pylock.toml or pyproject.toml.Python Environment
Python interpreter to use.By default, syncing requires a virtual environment. Use with caution for system Python.Environment:
UV_PYTHON--system
Use system Python instead of virtual environment.Environment:
UV_SYSTEM_PYTHON--break-system-packages
Allow installation into externally-managed Python environments.Environment:
UV_BREAK_SYSTEM_PACKAGESSync packages to the specified directory.
Sync packages to lib, bin folders under the specified directory.
Build Options
--no-build
Don’t build source distributions. Only use pre-built wheels.Alias for
--only-binary :all:Build specific packages from source.
Only use pre-built wheels for specific packages.
Pass settings to the PEP 517 build backend.
Pass package-specific settings to build backends.
--no-build-isolation
Disable build isolation. Assumes build dependencies are already installed.Environment:
UV_NO_BUILD_ISOLATIONIndex Options
Package indexes to use (in addition to default).Environment:
UV_INDEXDefault package index (replaces PyPI).Environment:
UV_DEFAULT_INDEXDeprecated: Use
--default-index instead.Environment: UV_INDEX_URLDeprecated: Use
--index instead.Environment: UV_EXTRA_INDEX_URLAdditional locations to search for packages.Environment:
UV_FIND_LINKS--no-index
Ignore package indexes, only use
--find-links.Index selection strategy:
first-index, unsafe-first-match, or unsafe-best-match.Default: first-indexEnvironment: UV_INDEX_STRATEGYKeyring provider for authentication:
disabled, subprocess.Default: disabledEnvironment: UV_KEYRING_PROVIDERHash Verification
--require-hashes
Require hash verification for all packages.All requirements must include hashes and be pinned to exact versions.Environment:
UV_REQUIRE_HASHES--no-verify-hashes
Disable hash verification.Environment:
UV_NO_VERIFY_HASHESVersion Constraints
Minimum Python version to support (e.g.,
3.8 or 3.8.17).Target platform triple (e.g.,
x86_64-unknown-linux-gnu).Sync Behavior
--allow-empty-requirements
Allow syncing with empty requirements, clearing the environment.
--strict
Validate environment after sync, detecting missing dependencies.
--dry-run
Show sync plan without making changes.
--reinstall
Reinstall all packages, ignoring existing installations.
Reinstall specific packages.
Exclude packages uploaded after the specified date.Environment:
UV_EXCLUDE_NEWERExclude specific packages uploaded after dates.
Link mode for installations:
clone, copy, hardlink, symlink.Default: clone on macOS/Linux, hardlink on WindowsEnvironment: UV_LINK_MODE--compile-bytecode
Compile Python files to bytecode after installation.Environment:
UV_COMPILE_BYTECODEuv Extensions
PyTorch backend: Environment:
cpu, cu126, cu124, cu121, cu118, or auto.Preview feature. May change in future releases.
UV_TORCH_BACKENDCache Options
--refresh
Refresh all cached data.
Refresh cached data for specific packages.
Examples
Basic Sync
With Extras
Dry Run
Hash Verification
Custom Index
Cross-Platform
Differences from pip install
uv pip sync differs from uv pip install in key ways:
Exact Sync
Expected Input
uv pip sync expects a fully resolved file (from uv pip compile or uv export):
Transitive Dependencies
If the input file is missing transitive dependencies, they won’t be installed:Use Cases
CI/CD Reproducible Builds
Development Workflow
Docker Images
Cleanup Environments
Related Commands
uv pip compile- Generate lockfileuv pip install- Install packages (keeps existing)uv sync- Sync project environment