Say goodbye to cumbersome Python environment management! uv is an efficient and convenient tool that can solve Python version management, virtual environment creation, package management, project management and other problems in one stop. It is fast and easy to get started. This article will take Windows PowerShell as an example to demonstrate the use of uv. For other platforms, you can refer to the official documentation for corresponding adjustments.
Install uv
uv does not depend on Python, so it is not recommended to use pip or pipx to install. Windows systems can be installed directly by executing the following command through PowerShell:
powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"
Or install using a package manager such as scoop:
scoop install uv
Use uv to manage multiple versions of Python
Use the uv python list
command to view installable and installed Python versions:
# uv python list cpython-3.13.1+freethreaded-windows-x86_64-none <download available=""> cpython-3.13.1-windows-x86_64-none <download available=""> cpython-3.12.8-windows-x86_64-none <download available=""> ...
Install the latest version:
# uv python install Installed Python 3.13.1 in 5.89s + cpython-3.13.1-windows-x86_64-none
View installation results: The installed version will display the installation path.
# uv python list cpython-3.13.1-windows-x86_64-none C:\Users\meebo\AppData\Roaming\uv\python\cpython-3.13.1-windows-x86_64-none\python.exe ...
Get the Python installation path:
# uv python dir C:\Users\meebo\AppData\Roaming\uv\python
Install the specified version:
# uv python install 3.10 Installed Python 3.10.16 in 9.78s + cpython-3.10.16-windows-x86_64-none
Uninstall Python version (requires specified version):
# uv python uninstall 3.10 Searching for Python versions matching: Python 3.10 Uninstalled Python 3.10.16 in 1.52s - cpython-3.10.16-windows-x86_64-none
View all versions (including all revisions): uv python list --all-versions
Install multiple versions: uv python install 3.10 3.11
Uninstall multiple versions: uv python uninstall 3.10 3.11
Use uv instead of python/pip tools
The Python environment managed by uv cannot be executed directly with the python
command, but must be executed through the uv run
command. For example:
# cat .\show_version.py import sys print(sys.version)
Execution:
# uv run .\show_version.py 3.13.1 (main, Dec 19 2024, 14:38:48) [MSC v.1942 64 bit (AMD64)]
Specify Python version to execute: uv run --python 3.10 .show_version.py
Execute from standard input: echo 'print("hello world!")' | uv run -
View installed Python version: uv python list --only-installed
Set default Python version (current directory only): uv python pin 3.10
(create .python-version
file)
Specify the packages required for execution
If the program requires additional packages, such as cowsay
:
# cat .\cow.py from cowsay import cow cow('hello, world')
Specify the package using the --with
option:
# uv run --with cowsay .\cow.py Installed 1 package in 13ms ...
Clear cached virtual environments: uv cache clean
Manage virtual environments
Create a virtual environment: uv venv --python 3.10
(create .venv
directory) or specify the directory name: uv venv myenv
Use the specified virtual environment: uv run --python myenv .show_version.py
Delete virtual environment: Delete virtual environment directory
Management Pack
Use the uv pip
command to manage packages, which is compatible with the pip
command.
Installation package: uv pip install cowsay
View package dependencies: uv pip tree
Uninstall package: uv pip uninstall rich
(Dependent packages no longer needed will not be automatically deleted)
Use uv to manage Python projects
uv provides two project management methods: single file project and folder project.
Single file project
Initialize single file project: uv init --script cow3.py --python 3.13
(add metadata in cow3.py
file)
Add package: uv add --script cow3.py cowsay rich
(modify cow3.py
file metadata)
Remove package: uv remove --script cow3.py rich
(modify cow3.py
file metadata)
Folder Items
Initialize the folder project: uv init myproject
(Create the project directory, including .gitignore
, .python-version
, hello.py
, pyproject.toml
, README.md
)
Execution project: uv run hello.py
(Create .venv
virtual environment)
Add package: uv add cowsay rich
(modify pyproject.toml
file)
Update package: uv lock --upgrade-package cowsay
or uv lock --upgrade
Remove package: uv remove cowsay
Synchronize project environment with uv.lock
files: uv sync
View project package dependencies: uv tree
Use the tool commands provided by the package
Directly execute the package command: uvx cowsay -t 'hello, uv'
or uv tool run cowsay -t 'hello, uv'
Specify package execution command: uvx --from httpie http -p=b GET https://flagtech.github.io/flag.txt
Install package command to the system: uv tool install httpie
Update package command: uv tool upgrade httpie
Uninstall package command: uv tool uninstall httpie
uv provides an efficient and convenient Python environment management solution, significantly improving development efficiency. Through the introduction of this article, I believe you have mastered the basic usage of uv and can better manage your Python projects and environments.
The above is the detailed content of Use uv to manage Python environments. For more information, please follow other related articles on the PHP Chinese website!

Hot AI Tools

Undress AI Tool
Undress images for free

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics

Python's unittest and pytest are two widely used testing frameworks that simplify the writing, organizing and running of automated tests. 1. Both support automatic discovery of test cases and provide a clear test structure: unittest defines tests by inheriting the TestCase class and starting with test\_; pytest is more concise, just need a function starting with test\_. 2. They all have built-in assertion support: unittest provides assertEqual, assertTrue and other methods, while pytest uses an enhanced assert statement to automatically display the failure details. 3. All have mechanisms for handling test preparation and cleaning: un

PythonisidealfordataanalysisduetoNumPyandPandas.1)NumPyexcelsatnumericalcomputationswithfast,multi-dimensionalarraysandvectorizedoperationslikenp.sqrt().2)PandashandlesstructureddatawithSeriesandDataFrames,supportingtaskslikeloading,cleaning,filterin

Dynamic programming (DP) optimizes the solution process by breaking down complex problems into simpler subproblems and storing their results to avoid repeated calculations. There are two main methods: 1. Top-down (memorization): recursively decompose the problem and use cache to store intermediate results; 2. Bottom-up (table): Iteratively build solutions from the basic situation. Suitable for scenarios where maximum/minimum values, optimal solutions or overlapping subproblems are required, such as Fibonacci sequences, backpacking problems, etc. In Python, it can be implemented through decorators or arrays, and attention should be paid to identifying recursive relationships, defining the benchmark situation, and optimizing the complexity of space.

To implement a custom iterator, you need to define the __iter__ and __next__ methods in the class. ① The __iter__ method returns the iterator object itself, usually self, to be compatible with iterative environments such as for loops; ② The __next__ method controls the value of each iteration, returns the next element in the sequence, and when there are no more items, StopIteration exception should be thrown; ③ The status must be tracked correctly and the termination conditions must be set to avoid infinite loops; ④ Complex logic such as file line filtering, and pay attention to resource cleaning and memory management; ⑤ For simple logic, you can consider using the generator function yield instead, but you need to choose a suitable method based on the specific scenario.

Future trends in Python include performance optimization, stronger type prompts, the rise of alternative runtimes, and the continued growth of the AI/ML field. First, CPython continues to optimize, improving performance through faster startup time, function call optimization and proposed integer operations; second, type prompts are deeply integrated into languages ??and toolchains to enhance code security and development experience; third, alternative runtimes such as PyScript and Nuitka provide new functions and performance advantages; finally, the fields of AI and data science continue to expand, and emerging libraries promote more efficient development and integration. These trends indicate that Python is constantly adapting to technological changes and maintaining its leading position.

Python's socket module is the basis of network programming, providing low-level network communication functions, suitable for building client and server applications. To set up a basic TCP server, you need to use socket.socket() to create objects, bind addresses and ports, call .listen() to listen for connections, and accept client connections through .accept(). To build a TCP client, you need to create a socket object and call .connect() to connect to the server, then use .sendall() to send data and .recv() to receive responses. To handle multiple clients, you can use 1. Threads: start a new thread every time you connect; 2. Asynchronous I/O: For example, the asyncio library can achieve non-blocking communication. Things to note

Polymorphism is a core concept in Python object-oriented programming, referring to "one interface, multiple implementations", allowing for unified processing of different types of objects. 1. Polymorphism is implemented through method rewriting. Subclasses can redefine parent class methods. For example, the spoke() method of Animal class has different implementations in Dog and Cat subclasses. 2. The practical uses of polymorphism include simplifying the code structure and enhancing scalability, such as calling the draw() method uniformly in the graphical drawing program, or handling the common behavior of different characters in game development. 3. Python implementation polymorphism needs to satisfy: the parent class defines a method, and the child class overrides the method, but does not require inheritance of the same parent class. As long as the object implements the same method, this is called the "duck type". 4. Things to note include the maintenance

The core answer to Python list slicing is to master the [start:end:step] syntax and understand its behavior. 1. The basic format of list slicing is list[start:end:step], where start is the starting index (included), end is the end index (not included), and step is the step size; 2. Omit start by default start from 0, omit end by default to the end, omit step by default to 1; 3. Use my_list[:n] to get the first n items, and use my_list[-n:] to get the last n items; 4. Use step to skip elements, such as my_list[::2] to get even digits, and negative step values ??can invert the list; 5. Common misunderstandings include the end index not
