」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 使用 uv 掌握 Python 專案管理 PartIt&#s Time to Ditch Poetry

使用 uv 掌握 Python 專案管理 PartIt&#s Time to Ditch Poetry

發佈於2024-11-04
瀏覽:388

Mastering Python Project Management with uv PartIt

您是否厌倦了为了控制 Python 环境和依赖项而使用 pip、virtualenv、conda、poetry 和 pyenv 等多个工具?你并不孤单!管理 Python 项目可能会让人感到头疼,尤其是在需要处理各种不同的包管理器和工具的情况下。

输入 uv通用 Virtualenv。将其视为一站式包管理器,旨在简化和加速您的 Python 开发过程。


一些背景故事

uv 从另一位现代打包管理器 Rye 中汲取灵感,统一了 pip、pip-tools、pyenv、virtualenv 和 Poetry 的最佳功能。 uv 使用 Rust 构建,不仅速度快,而且效率高,简化了从管理依赖项到创建虚拟环境的一切。

紫外线的目的

简而言之,uv 就是整合。当您可以获得一种统一的体验时,为什么要在多种工具之间切换?它旨在消除 Python 开发中的摩擦,为您提供更一致、更快速的项目管理方式。而且速度还很快!这为动态管理打开了新的大门


1. 带有内联脚本元数据的可移植代码

让我们谈谈依赖关系

uv 最令人兴奋的功能之一是能够直接在 Python 脚本中添加依赖项。想象一下你有一个像这样的简单脚本:

# app.py
import requests
from rich.pretty import pprint

response = requests.get("https://peps.python.org/api/peps.json")
data = response.json()
pprint([(k, v["title"]) for k, v in data.items()][:10])

运行此脚本通常意味着设置虚拟环境并手动安装依赖项。使用 uv,您可以将所有依赖项直接嵌入到脚本中,使其成为自包含可共享

$ uv add --script app.py 'requests



自动元数据生成

这会将元数据添加到脚本文件中:

# /// script
# dependencies = [
#   "requests



就是这样!您可以与其他人共享此文件,他们只需运行:

$ uv run app.py

瞧——无需外部设置!这一切都归功于 uv 的速度和效率。


2. 创建和管理虚拟环境

虚拟环境入门

默认情况下,uv 要求在虚拟环境中安装软件包,以保持系统干净并避免不同项目之间的冲突。用uv创建虚拟环境很简单:

$ uv venv

这将创建一个包含隔离环境的 .venv 目录。如果你想指定自定义目录或Python版本,你可以这样做:

$ uv venv my_env --python 3.9

环境已准备好使用,uv 将自动检测您的所有命令,例如安装包或运行脚本。

何时使用 uv add 与 uv pip install

  • 使用 uv add:当你想向项目的 pyproject.toml 文件添加依赖项时。当您正在开发项目并希望跟踪所有依赖项以使项目易于共享和复制时,这是最好的选择。我们将在下一篇文章中对此进行介绍,敬请期待!

    $ uv add fastapi
    

    这将更新您的 pyproject.toml 并将版本锁定在 uv.lock 中。

  • 使用 uv pip install:当您想要安装包以快速使用而不修改项目文件时,或者对于不需要在 pyproject.toml 中跟踪它们的全局工具时。将 uv pip 视为一种直接的一次性安装。

    $ uv pip install requests
    

选择正确的命令可确保您的项目得到正确管理并易于共享或部署。


3. 锁定版本以实现可重复性

您的代码是否曾因更新而被破坏过?

我们都经历过这样的情况——您的代码今天可以运行,但明天就会因为包更新而崩溃。使用 uv,您可以通过锁定软件包版本来防止这种情况,以确保一致性和可重复性:

[tool.uv]
exclude-newer = "2023-10-16T00:00:00Z"

这样,即使出现新版本的依赖项,您的项目也保持稳定。非常适合无法承受意外的长期项目!


4. 管理Python版本

不同的项目,不同的Python版本?没问题!

许多开发人员必须处理需要不同 Python 版本的多个项目。 uv 让切换版本变得如此简单:

$ uv python install 3.8 3.9 3.10

安装版本后,它们之间的切换是无缝的:

$ uv run --python 3.10 app.py

如果您想锁定项目的特定版本:

$ uv python pin 3.9

不再需要杂耍 pyenv 命令——uv 会为您处理所有繁重的工作。


5. 告别 pip 麻烦

虽然是点,但更快更好

uv 提供类似 pip 的体验,但具有涡轮增压的性能。安装软件包很简单:

$ uv pip install flask

需要添加可选依赖项或直接从 GitHub 存储库安装?不费吹灰之力:

$ uv pip install 'torch>=1.10.0' "git https://github.com/astral-sh/ruff"

不再需要等待缓慢的安装 - uv 可以快速有效地完成工作。


6. 轻松全局管理 CLI 工具

从黑色到皱褶,轻松获取您的工具

无论您是要检查代码还是格式化文件,uv 都可以让安装 CLI 工具变得简单:

  • 全球

    $ uv tool install ruff
    
  • 项目内本地

    $ uv add ruff
    
  • 运行临时命令而不全局安装:

    $ uvx black my_code.py
    

告别包冲突和环境污染——随时随地运行您的工具。


如果您希望增强您的 Python 开发能力并希望停止使用多种工具,uv 就是您的答案。凭借其简化的命令、可重现的环境和高效的包管理,uv 使 Python 开发成为一种乐趣而不是一件苦差事。

准备好尝试一下紫外线了吗? ?从今天开始,体验管理 Python 项目的更好方法。


请继续关注第 2 部分,我们将深入探讨高级功能,例如利用 pyproject.toml、处理全局与本地工具安装,以及 uv 如何成为管理复杂环境时最好的朋友。

编码愉快! ?✨

有关更多详细信息和完整文档,请查看 uv 文档。

版本聲明 本文轉載於:https://dev.to/thomas_bury_b1a50c1156cbf/mastering-python-project-management-with-uv-part1-its-time-to-ditch-poetry-3bi0?1如有侵犯,請聯絡study_golang@163 .com刪除
最新教學 更多>
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-14
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-14
  • 如何使用命令式方法更新 React 中的巢狀狀態?
    如何使用命令式方法更新 React 中的巢狀狀態?
    更新嵌套狀態的命令式方法在 React 中,狀態更新是不可變的。這意味著要更新嵌套物件或數組,您不能簡單地修改其屬性並期望變更反映在 UI 中。相反,您需要建立包含更新值的新物件或數組,然後將其傳遞給 setState。 考慮以下範例,其中我們要更新物件中索引 1 處的物件的 name 屬性儲存在狀...
    程式設計 發佈於2024-11-14
  • 原子變數有哪些不同的記憶體排序模型?
    原子變數有哪些不同的記憶體排序模型?
    瞭解記憶體排序的意思原子變數提供安全的記憶體存取和跨執行緒同步。了解不同的記憶體順序對於有效利用它們至關重要。 輕鬆:無記憶體同步。 可能重新排序的最佳化操作讀取和寫入。 順序一致 (seq_cst):最嚴格的排序。 防止對周圍的任何記憶體操作進行重新排序原子操作。 確保所有執行緒的記憶體存取一致。...
    程式設計 發佈於2024-11-14
  • 為什麼在 For 迴圈中放錯 Return 語句會影響輸入迴圈?
    為什麼在 For 迴圈中放錯 Return 語句會影響輸入迴圈?
    For循環中返回語句錯位在你的作業中,你遇到了一個問題,程式只允許輸入一隻寵物,儘管瞄準三個。這個問題源自於 make_list 函數中 return 語句的定位。 在 for 迴圈中,return 語句在到達函數時立即終止函數的執行。在提供的程式碼中,return 語句放置在循環內部,導致函數在第...
    程式設計 發佈於2024-11-14
  • 如何防止使用者關閉 Bootstrap 模式?
    如何防止使用者關閉 Bootstrap 模式?
    停用使用者啟動的 Bootstrap 模態退出您可以透過點選 Bootstrap 模態區域外部來阻止使用者關閉 Bootstrap 模態。這在您想要強制使用者在繼續操作之前與特定模態內容互動的情況下非常有用。 停用模態背景點擊關閉預設情況下,使用者可以透過點選模式視窗之外的任何位置來關閉模式。若要停...
    程式設計 發佈於2024-11-14
  • 如何在 Python 中將巢狀清單匯出到 CSV 檔案?
    如何在 Python 中將巢狀清單匯出到 CSV 檔案?
    在Python中將嵌套列表匯出到CSV檔案將嵌套列表(其中每個內部列表包含不同類型的元素)寫入CSV檔案可以在Python 中處理資料時這是一項常見任務。以下是應對這項挑戰的方法:Python 的 csv 模組提供了處理 CSV 作業的便利方法。若要將清單的清單(例如a = [[1.2,'a...
    程式設計 發佈於2024-11-14
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1和$array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建構一...
    程式設計 發佈於2024-11-14
  • 如何有效率地提取Go Slice的最後一個元素?
    如何有效率地提取Go Slice的最後一個元素?
    Go 提取切片最後一個元素的最佳方法在 Go 中使用切片時,有效操作元素至關重要。一個常見的任務是提取最後一個元素,這可以透過多種方法來實現。 現有解決方案的缺點使用切片提供的解決方案[len(slice)-1 :][0] 看起來很麻煩並且涉及不必要的複雜性。它會傳回一個僅包含最後一個元素的切片,然...
    程式設計 發佈於2024-11-14
  • 為什麼我的 JavaScript 事件在動態元素追加後沒有被觸發?
    為什麼我的 JavaScript 事件在動態元素追加後沒有被觸發?
    動態元素追加後 JavaScript 事件未觸發您遇到了向 DOM 追加新元素後 JavaScript 事件未觸發的問題。這是因為 jQuery 僅識別頁面載入期間最初執行時存在的元素。 要解決此問題,您需要使用事件委託來擷取動態元素中的事件。事件委託涉及擷取頁面載入期間已經存在的 DOM 中較高層...
    程式設計 發佈於2024-11-14
  • `unshift()` 是在 JavaScript 中將元素新增到陣列的最有效方法嗎?
    `unshift()` 是在 JavaScript 中將元素新增到陣列的最有效方法嗎?
    JavaScript 中的最佳數組前置將元素前置到數組的開頭是 JavaScript 中的常見要求。在這裡,我們探索一種比問題中建議的傳統方法更好的方法。 Unshift 方法:本機解決方案JavaScript 提供了一個名為 unshift 的內建方法有效地將元素新增至陣列的開頭。與涉及建立新陣列...
    程式設計 發佈於2024-11-14
  • 在 JavaScript 中透過建構函數定義方法是否會建立重複的函數副本?
    在 JavaScript 中透過建構函數定義方法是否會建立重複的函數副本?
    JavaScript 中透過原型與建構函數定義方法的效能影響在JavaScript 中,存在兩種建立具有公用函數的「類”的方法:使用原型或建構函數。方法 1 透過建構函式將函數指派給實例,而方法 2 利用原型在所有實例之間共用函數。 雖然方法 2 通常被認為更有效率,但剝奪實例的私有實例變數是一個顯...
    程式設計 發佈於2024-11-14
  • 如何使用 matcha.css 設定 HTML 樣式
    如何使用 matcha.css 設定 HTML 樣式
    Written by Emmanuel Odioko✏️ Matcha, a famous green tea, is known for its stress-reducing benefits. I wouldn't claim that this tea necessarily inspire...
    程式設計 發佈於2024-11-14
  • 如何在 PHP 中從物件數組中提取屬性列?
    如何在 PHP 中從物件數組中提取屬性列?
    從物件陣列中提取屬性列要從一行中的物件陣列中提取屬性列,我們可以使用PHP array_column()函數,在PHP 7.0 中引入。 $cats = Array( (object) ['id' => 15], (object) ['id' => 18], (o...
    程式設計 發佈於2024-11-14
  • 為什麼嘗試在 CSS 中創建淡出效果時我的幻燈片動畫不起作用?
    為什麼嘗試在 CSS 中創建淡出效果時我的幻燈片動畫不起作用?
    CSS3過渡:淡出效果當嘗試使用純CSS實現淡出效果時,可能會感到困惑為什麼幻燈片動畫行不通。原因如下:淡出效果的關鍵在於轉換不透明度屬性。 top屬性,用於幻燈片動畫,不會產生想要的效果。 使用CSS3 Transition的淡出效果下面是一個如何實現淡出效果的例子使用CSS3過渡的淡出效果:.h...
    程式設計 發佈於2024-11-14

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3