」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > 如何準確比較Python版本字串?

如何準確比較Python版本字串?

發佈於2024-11-18
瀏覽:630

How to Accurately Compare Python Version Strings?

如何優雅地比較Python版本字串

使用Python套件時,經常需要比較版本號。然而,比較字串版本可能會導致不正確的結果,因為字串順序可能與實際版本順序不符。

為了解決這個問題,Python 提供了 Packaging.version.Version 類,它支援 PEP 440版本字串排序的樣式。此方法允許準確比較版本字串,同時考慮特殊字元和預發布標識符。

使用 Version 很簡單:

from packaging.version import Version

version1 = Version("2.3.1")
version2 = Version("10.1.2")

print(version1 

與本機字串比較不同,Version 可以正確辨識「2.3.1」小於「10.1.2」。

另一個選項,儘管已棄用,是 distutils.version。雖然它沒有記錄並且符合過時的 PEP 386,但仍然可能會遇到:

from distutils.version import LooseVersion

version1 = LooseVersion("2.3.1")
version2 = LooseVersion("10.1.2")

print(version1 

然而,distutils.version 有局限性,無法正確處理 PEP 440 版本。

總之,為了準確地比較 Python 版本字串並以 Pythonic 方式方式,使用 Packaging.version.Version.

最新教學 更多>
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要一种比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSoc...
    程式設計 發佈於2024-11-18
  • 如何使用 Sequelize CLI 從 Sequelize 模型產生遷移?
    如何使用 Sequelize CLI 從 Sequelize 模型產生遷移?
    使用Sequelize CLI 從Sequelize 模型自動產生遷移人們可能擁有預先存在的Sequelize 模型,但希望使用遷移而不是資料庫同步。 Sequelize CLI 提供了一篇文章中概述的解決方案,其中指出,「當利用CLI 進行模型生成時,您將自動獲取必要的遷移腳本。」要實現此任務: ...
    程式設計 發佈於2024-11-18
  • 為什麼Selenium 2.53.0在使用Firefox 47時會遇到連線錯誤?
    為什麼Selenium 2.53.0在使用Firefox 47時會遇到連線錯誤?
    Selenium 2.53 與Firefox 47 不相容使用Selenium WebDriver 2.53.0 時,遇到錯誤:org.openqa.selenium.firefox.NotConnectedException: Unable to connect to host 127.0.0.1...
    程式設計 發佈於2024-11-18
  • 如何建立您的第一個 Web 應用程式:將想法變為現實的初學者指南
    如何建立您的第一個 Web 應用程式:將想法變為現實的初學者指南
    您对网络应用程序有一个想法,但您不确定如何或从哪里开始?构建 Web 应用程序听起来令人畏惧,特别是如果这是您第一次。然而,一步一步地,任何人都可以将他们的想法变成现实,只关注非常重要的组成部分。您将获得可操作的提示和资源,以及有关如何构建您的第一个 Web 应用程序的清晰路线图。 第 1 步:了...
    程式設計 發佈於2024-11-18
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-11-18
  • 如何只檢索 LEFT JOIN 中的第一行?
    如何只檢索 LEFT JOIN 中的第一行?
    僅檢索LEFT JOIN 中的第一行在SQL 中,執行LEFT JOIN 操作可能會導致右表中出現多行與左表中的一行相符。在某些情況下,希望為左表中的每一行僅檢索右表中的第一行。 考慮以下簡化的資料結構:**Feeds** id | title | content -----------------...
    程式設計 發佈於2024-11-18
  • 如何修復 C++ 中指標與整數之間的比較錯誤
    如何修復 C++ 中指標與整數之間的比較錯誤
    C 中的比較錯誤:指針與整數在Bjarne Stroustrup 的C 書籍第三版開發人員中嘗試編譯一個簡單函數時可能會遇到編譯時錯誤:error: ISO C forbids comparison between pointer and integer將指標與整數進行比較時會出現此問題。在提供...
    程式設計 發佈於2024-11-18
  • 為什麼我的 Keras 模型僅在資料集的一部分上進行訓練?
    為什麼我的 Keras 模型僅在資料集的一部分上進行訓練?
    Keras 訓練資料差異在按照官方TensorFlow 指南使用Keras 建立神經網路時,您注意到該模型僅使用儘管有60,000個條目,但訓練期間可用資料集的一部分。 了解批量大小模型擬合期間顯示的數字 1875 並不表示訓練樣本,而是表示批次數量。 model.fit 方法有一個可選參數,bat...
    程式設計 發佈於2024-11-18
  • Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta 中的列偏移發生了什麼事?
    Bootstrap 4 Beta:列偏移的刪除和恢復Bootstrap 4 在其Beta 1 版本中引入了重大更改柱子偏移了。然而,隨著 Beta 2 的後續發布,這些變化已經逆轉。 從 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    程式設計 發佈於2024-11-18
  • 為什麼推遲 GZIP Writer 關閉會導致 Go 中的資料遺失?
    為什麼推遲 GZIP Writer 關閉會導致 Go 中的資料遺失?
    延遲GZIP Writer 關閉會導致資料遺失延遲GZIP Writer 關閉會導致資料遺失在Go 中,使用defer 關閉gzip.Writer 可能會導致意外的EOF 錯誤從壓縮資料中讀取。要解決此問題,讓我們深入研究問題的具體情況並提供替代解決方案。 理解問題:func zipData(ori...
    程式設計 發佈於2024-11-18
  • 介面如何實現超越簡單方法定義的多態性?
    介面如何實現超越簡單方法定義的多態性?
    多態性:不只是方法定義在物件導向程式設計中,介面在確保程式碼靈活性和可重用性方面發揮著至關重要的作用。雖然您正確地聲明介面只需要實作它們的類別來提供必要的方法,但它們的真正價值遠遠超出了方法聲明。 考慮您提供的範例,使用 IBox 介面和 Rectangle 類別。直接建立 IBox 實例是不可能的...
    程式設計 發佈於2024-11-18
  • 為什麼 Java 中的陣列不能保存通用項?
    為什麼 Java 中的陣列不能保存通用項?
    陣列可以儲存泛型項嗎? 泛型型別和陣列在 Java 中的互動方式不同。考慮以下程式碼:ArrayList<Key> a = new ArrayList<Key>();此程式碼編譯成功,建立一個名為 a 的通用 ArrayList。但是,下面的程式碼無法編譯通過:ArrayLi...
    程式設計 發佈於2024-11-18
  • 為什麼鍵入「String」後 Eclipse 的 Java 程式碼補全不起作用?
    為什麼鍵入「String」後 Eclipse 的 Java 程式碼補全不起作用?
    Eclipse/Java 程式碼完成故障:故障排除Eclipse 是一種流行的Java 開發環境,偶爾會遇到程式碼完成功能的問題。當使用者在輸入“String”後按下“Ctrl”“Space”時遇到程式碼完成無法產生建議的情況時,就會出現這樣的問題。該問題表現為「無預設提案」訊息,並伴隨指示未完成的...
    程式設計 發佈於2024-11-18
  • 將 fetchall() 與 MySQLDB SSCursor 結合使用對於大型資料集實際上有效嗎?
    將 fetchall() 與 MySQLDB SSCursor 結合使用對於大型資料集實際上有效嗎?
    高效利用MySQLDB SSCursor 處理大型結果集處理涉及數十萬或更多行的龐大結果集時,高效的內存管理變得尤為重要至關重要的。因此,MySQLDB SScursor(串流選擇遊標)成為最小化記憶體消耗的合適工具。 有基礎遊標的Fetchall() 與SSCursor 的差異與普遍看法相反,從S...
    程式設計 發佈於2024-11-18
  • 我如何在前端使用 Service Worker 最佳化載入時間
    我如何在前端使用 Service Worker 最佳化載入時間
    您是否遇到過網站載入時間過長的情況,如下圖所示? ?你聽過服務人員嗎? 在這篇文章中,我們將深入探討什麼是 Service Worker? 、它們如何運作 ⚙️,以及我如何使用它們來提高 Web 應用程式的效能。 什麼是 Service Worker? ? Service Worker 是一...
    程式設計 發佈於2024-11-18

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

Copyright© 2022 湘ICP备2022001581号-3