為Python程序添加模塊和依賴: setup.py的用法

對於Python開發者來說,寫好代碼並不是唯一的步驟,還需要將代碼打包成模塊,並且加上依賴關係。這樣其他開發者在使用你的模塊時就可以更方便地調用並且避免重複造輪子。Python的標準庫中提供了setuptools,通過setup.py腳本可以製作出一個可發布的Python模塊並且管理依賴關係。

一、創建setup.py文件

要使用setuptools創建一個可發布的Python模塊,首先在項目根目錄下創建一個名為setup.py的文件。setup.py文件是用來描述Python模塊如何安裝、構建以及打包的腳本,簡單來說就是模塊的說明書。

from setuptools import setup, find_packages

setup(
    name='example',  # 模塊名
    version='0.1',  # 版本號
    packages=find_packages(),  # 包含的包
    install_requires=['numpy>=1.16.6', 'pandas>=0.24.2'],  # 依賴的第三方庫
    test_suite='nose.collector',
    tests_require=['nose'],
    entry_points={
        'console_scripts': [
            'example = example.app:start'
        ]
    },
    classifiers=[
        "Programming Language :: Python :: 3",
        "License :: OSI Approved :: MIT License",
        "Operating System :: OS Independent",
    ]
)

這裡導入了setuptools的setup()函數和find_packages()函數。setup()函數的參數包含了很多可以設置的選項,例如模塊名、版本號、包含的包、依賴關係、可執行文件等。

二、設置版本號

版本號是一個Python模塊最重要的元素之一。通過給模塊設置版本號,可以使你的代碼與其他依賴關係和版本號兼容的代碼一起工作,還可以根據需要更輕鬆地追蹤和管理你的代碼的進展。

設置版本號的通常方式是修改setup.py文件中的version參數,如下所示:

setup(
    name='example',
    version='0.1',
    # ...
)

版本號通常由兩個邏輯部分構成:主版本號和次版本號。主版本號通常表示代碼中引入了重大變化或不向後兼容的更改,而次版本號通常表示一些小的增強、重構或者錯誤修復。

三、依賴管理

依賴管理是打包Python模塊時必不可少的一部分。一般來說,一個Python模塊可能會依賴於其他的第三方模塊,這些模塊需要在安裝前先安裝。

可以在setup.py的install_requires選項中聲明你的Python模塊的依賴項,例如:

setup(
    name='example',
    version='0.1',
    install_requires=['numpy>=1.16.6', 'pandas>=0.24.2'],
    # ...
)

這裡聲明了numpy和pandas兩個第三方庫的依賴,且要求版本號不低於某個值。

四、生成可執行文件

有時,一個Python模塊可以生成可執行文件。例如,一些工具可以在命令行中運行,而不是直接運行Python代碼。在Python中,可以使用setuptools的entry_points選項來定義一個可執行文件。

下面是一個例子:

setup(
    name='example',
    version='0.1',
    # ...
    entry_points={
        'console_scripts': [
            'example = example.app:start'
        ]
    },
    # ...
)

這裡,我們將example.app:start作為可執行文件的入口點。一旦模塊被安裝,用戶就可以運行example作為命令,並調用到example模塊的start()函數。

五、構建和發布Python模塊

在設置好setup.py文件後,可以使用setuptools來構建和發布Python模塊了。要構建模塊,請在命令行中進入包含setup.py文件的目錄,並執行以下命令:

python setup.py sdist

這將創建一個源分發包(.tar.gz)。如果同時也想為其他操作系統和Python版本構建二進制分發包(.whl),可以使用以下命令:

python setup.py bdist_wheel

最後,通過如下命令上傳分發包到PyPI:

twine upload dist/*

其中,twine是PyPI官方的上傳工具。在執行此命令前,請確保你已在PyPI上註冊了帳戶。

六、總結

Python的setuptools是一個非常方便的打包工具,不僅能夠管理依賴關係,還能方便地發布Python模塊。一個好的Python模塊應該是易於安裝、易於調用,而設置好的setup.py文件就是實現這些目標的重要一環。

原創文章,作者:KVUP,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/135941.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
KVUP的頭像KVUP
上一篇 2024-10-04 00:15
下一篇 2024-10-04 00:15

相關推薦

  • Python中引入上一級目錄中函數

    Python中經常需要調用其他文件夾中的模塊或函數,其中一個常見的操作是引入上一級目錄中的函數。在此,我們將從多個角度詳細解釋如何在Python中引入上一級目錄的函數。 一、加入環…

    編程 2025-04-29
  • Python列表中負數的個數

    Python列表是一個有序的集合,可以存儲多個不同類型的元素。而負數是指小於0的整數。在Python列表中,我們想要找到負數的個數,可以通過以下幾個方面進行實現。 一、使用循環遍歷…

    編程 2025-04-29
  • Python周杰倫代碼用法介紹

    本文將從多個方面對Python周杰倫代碼進行詳細的闡述。 一、代碼介紹 from urllib.request import urlopen from bs4 import Bea…

    編程 2025-04-29
  • 如何查看Anaconda中Python路徑

    對Anaconda中Python路徑即conda環境的查看進行詳細的闡述。 一、使用命令行查看 1、在Windows系統中,可以使用命令提示符(cmd)或者Anaconda Pro…

    編程 2025-04-29
  • Python計算陽曆日期對應周幾

    本文介紹如何通過Python計算任意陽曆日期對應周幾。 一、獲取日期 獲取日期可以通過Python內置的模塊datetime實現,示例代碼如下: from datetime imp…

    編程 2025-04-29
  • Python清華鏡像下載

    Python清華鏡像是一個高質量的Python開發資源鏡像站,提供了Python及其相關的開發工具、框架和文檔的下載服務。本文將從以下幾個方面對Python清華鏡像下載進行詳細的闡…

    編程 2025-04-29
  • Python程序需要編譯才能執行

    Python 被廣泛應用於數據分析、人工智能、科學計算等領域,它的靈活性和簡單易學的性質使得越來越多的人喜歡使用 Python 進行編程。然而,在 Python 中程序執行的方式不…

    編程 2025-04-29
  • 蝴蝶優化算法Python版

    蝴蝶優化算法是一種基於仿生學的優化算法,模仿自然界中的蝴蝶進行搜索。它可以應用於多個領域的優化問題,包括數學優化、工程問題、機器學習等。本文將從多個方面對蝴蝶優化算法Python版…

    編程 2025-04-29
  • python強行終止程序快捷鍵

    本文將從多個方面對python強行終止程序快捷鍵進行詳細闡述,並提供相應代碼示例。 一、Ctrl+C快捷鍵 Ctrl+C快捷鍵是在終端中經常用來強行終止運行的程序。當你在終端中運行…

    編程 2025-04-29
  • Python字典去重複工具

    使用Python語言編寫字典去重複工具,可幫助用戶快速去重複。 一、字典去重複工具的需求 在使用Python編寫程序時,我們經常需要處理數據文件,其中包含了大量的重複數據。為了方便…

    編程 2025-04-29

發表回復

登錄後才能評論