溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

利用pip怎么發(fā)布一個Python程序

發(fā)布時間:2021-03-26 15:47:25 來源:億速云 閱讀:193 作者:Leah 欄目:開發(fā)技術(shù)

這期內(nèi)容當(dāng)中小編將會給大家?guī)碛嘘P(guān)利用pip怎么發(fā)布一個Python程序,文章內(nèi)容豐富且以專業(yè)的角度為大家分析和敘述,閱讀完這篇文章希望大家可以有所收獲。

1. 環(huán)境準(zhǔn)備

要用 pip 發(fā)布 python 程序,首先當(dāng)然是要安裝 Python 和 pip 這兩個軟件了,以 Ubuntu 16.04 為例:

$ sudo apt update 
$ sudo apt install -y python python-pip

CentOS 和 RedHat 因為 RPM 體系需要依賴于 python,更是默認(rèn)就安裝好了。

另外發(fā)布 Pypi,還需要安裝一個發(fā)布工具, twine ,以及其所依賴的 setuptools、wheel:

$ sudo pip install --upgrade twine setuptools wheel

好,到這環(huán)境就已經(jīng)就緒了。

2. 注冊帳號

pip 上傳代碼包是最終保存在 https://pypi.org 這個網(wǎng)站上的,所以要用 pip 發(fā)布程序,就需要在這個網(wǎng)站上注冊一個帳號。

訪問該網(wǎng)址進(jìn)行注冊: https://pypi.org/account/register/

利用pip怎么發(fā)布一個Python程序

注冊后還需要進(jìn)行郵箱驗證,流程和普通網(wǎng)站沒有任何區(qū)別,所以具體步驟就不在這里詳細(xì)介紹了。

3. 代碼結(jié)構(gòu)

要發(fā)布 Python 程序,程序的結(jié)構(gòu)必須符合特定的要求,假設(shè)要發(fā)布的程序名為 example-pkg,基本的目錄結(jié)構(gòu)如下:

/example-pkg
 /example-pkg
  __init__.py
 setup.py
 LICENSE
 README.md

說一下目錄和文件的含義:

  • 首先最外層要建立一個和發(fā)出程序同名的文件夾: /example-pkg

  • 該文件夾下還要再簡歷一個同名文件夾,用來存放程序代碼: /example-pkg/example-pkg

  • Python 的老規(guī)矩,example-pkg/example-pkg 目錄下當(dāng)然要有一個 __init__.py 文件。

  • /example-pkg 目錄下要有一個叫 setup.py 的文件,如果下載過 Python 代碼包,應(yīng)該都知道這個文件,需要通過這個文件進(jìn)行 Python 代碼的編譯(可能會有依賴的其他代碼包或者依賴的 C 文件)和安裝。

  • LICENSE 文件:這個文件就是用來保存代碼所使用的開源許可證。

  • README.md:這個是軟件行業(yè)的慣例了,幫助文檔。

對于 setup.py 文件,還有必要好好說說,先貼個例子,下面這個例子中,主要是實現(xiàn)了從 /example-pkg/example-pkg/__init__.py 文件中讀取 version 參數(shù),來配置當(dāng)前軟件的版本,并指定了代碼包名(name)、作者(author)、郵箱(author_email)、描述信息(long_description、long_description_content_type)、依賴(install_requires),以及哪些文件不會被打包到程序中(exclude_package_data)。

另外需要提醒大家一點, 給程序起名字不要帶下劃線(_) ,python import 代碼包時,是不支持下劃線包名的,出現(xiàn)這種情況就比較尷尬,代碼裝上了,還是用不了。

#!/usr/bin/env python

import re
import setuptools

version = ""
with open('example-pkg/__init__.py', 'r') as fd:
  version = re.search(r'^__version__\s*=\s*[\'"]([^\'"]*)[\'"]',
            fd.read(), re.MULTILINE).group(1)

with open("README.md", "r") as fh:
  long_description = fh.read()

setuptools.setup(
  name="example-pkg",
  version=version,
  author="example",
  author_email="author@example.com",
  description="This is the SDK for example.",
  long_description=long_description,
  long_description_content_type="text/markdown",
  url="http://example.com",
  install_requires=[
    'requests!=2.9.0',
    'lxml>=4.2.3',
    'monotonic>=1.5',
  ],
  packages=setuptools.find_packages(exclude=("test")),
  classifiers=(
    "License :: OSI Approved :: MIT License",
    "Intended Audience :: Developers",
    "Operating System :: OS Independent",
    "Programming Language :: Python",
    "Programming Language :: Python :: 2",
    "Programming Language :: Python :: 2.6",
    "Programming Language :: Python :: 2.7",
    "Programming Language :: Python :: 3",
    "Programming Language :: Python :: 3.3",
    "Programming Language :: Python :: 3.4",
    "Programming Language :: Python :: 3.5"
  ),
  exclude_package_data={'': ["example-pkg/test.py", "example-pkg/config.txt"]},
)

4. 上傳和檢查

一切準(zhǔn)備就緒,下面就可以執(zhí)行打包命令,產(chǎn)生要上傳的代碼包了:

$ python setup.py sdist bdist_wheel

執(zhí)行結(jié)束后,會產(chǎn)生如下目錄和文件:

/example-pkg/dist/
 example-pkg-0.0.1-py3-none-any.whl
 example-pkg-0.0.1.tar.gz

包有了,就差上傳了,執(zhí)行第一步中安裝的 twine 命令:

$ twine upload dist/*
Uploading distributions to https://upload.pypi.org/legacy/
Enter your username: <your pypi.org username>
Enter your password: <your pypi.org password>
Uploading example-pkg-0.0.1-py3-none-any.whl
100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 45.0k/45.0k [00:01<00:00, 24.0kB/s]
Uploading example-pkg-0.0.1.tar.gz
100%|█████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████████| 43.8k/43.8k [00:00<00:00, 46.2kB/s]

上傳完畢!不過這里有一點需要注意,上傳新版本后,很可能 pip search 還沒法查到版本的更新,這是正常的,我理解是

pip search 命令依賴于緩存,所以不會立刻生效。

接下來就讓我們下載自己剛剛上傳的 python 試試吧:

$ pip install example-pkg
$ python
>>> import example-pkg
>>> example-pkg.name
'example-pkg'

最后再補(bǔ)充一點,上傳可能會失敗,提示無法上傳指定的代碼包,此時很大的可能是 pypi 中已經(jīng)有了相同的代碼包,所以建議在上傳之前,先搜索一下是否有重名的代碼包,選擇一個不沖突的名字,再上傳。

例如下面這個例子,example-pkg 已經(jīng)存在了,如果要再上傳,那當(dāng)然會失敗,換個名字就解決了。

$ pip search example-pkg
example-pkg (0.0.7)                      - A small example package
......

上述就是小編為大家分享的利用pip怎么發(fā)布一個Python程序了,如果剛好有類似的疑惑,不妨參照上述分析進(jìn)行理解。如果想知道更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI