使用pip發(fā)布Python程序的方法步驟
寫過 Python 程序的小伙伴們都知道,需要 import 個(gè)非 Python 自帶的軟件包時(shí),都要用到 pip 這個(gè)程序。平時(shí)我們都是用 pip,如果我們寫好了一個(gè)程序,想讓大家都能用的到,那么是不是也可以通過 pip 發(fā)布出去呢?
答案當(dāng)然是可以了,這篇文章我們就來看看如何用 pip 發(fā)布一個(gè) python 程序。
1. 環(huán)境準(zhǔn)備
要用 pip 發(fā)布 python 程序,首先當(dāng)然是要安裝 Python 和 pip 這兩個(gè)軟件了,以 Ubuntu 16.04 為例:
$ sudo apt update $ sudo apt install -y python python-pip
CentOS 和 RedHat 因?yàn)?RPM 體系需要依賴于 python,更是默認(rèn)就安裝好了。
另外發(fā)布 Pypi,還需要安裝一個(gè)發(fā)布工具, twine ,以及其所依賴的 setuptools、wheel:
$ sudo pip install --upgrade twine setuptools wheel
好,到這環(huán)境就已經(jīng)就緒了。
2. 注冊帳號(hào)
pip 上傳代碼包是最終保存在 https://pypi.org 這個(gè)網(wǎng)站上的,所以要用 pip 發(fā)布程序,就需要在這個(gè)網(wǎng)站上注冊一個(gè)帳號(hào)。
訪問該網(wǎng)址進(jìn)行注冊: https://pypi.org/account/register/

注冊后還需要進(jìn)行郵箱驗(yà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
說一下目錄和文件的含義:
- 首先最外層要建立一個(gè)和發(fā)出程序同名的文件夾: /example-pkg
- 該文件夾下還要再簡歷一個(gè)同名文件夾,用來存放程序代碼: /example-pkg/example-pkg
- Python 的老規(guī)矩,example-pkg/example-pkg 目錄下當(dāng)然要有一個(gè)
__init__.py文件。 - /example-pkg 目錄下要有一個(gè)叫 setup.py 的文件,如果下載過 Python 代碼包,應(yīng)該都知道這個(gè)文件,需要通過這個(gè)文件進(jìn)行 Python 代碼的編譯(可能會(huì)有依賴的其他代碼包或者依賴的 C 文件)和安裝。
- LICENSE 文件:這個(gè)文件就是用來保存代碼所使用的開源許可證。
- README.md:這個(gè)是軟件行業(yè)的慣例了,幫助文檔。
對(duì)于 setup.py 文件,還有必要好好說說,先貼個(gè)例子,下面這個(gè)例子中,主要是實(shí)現(xiàn)了從 /example-pkg/example-pkg/__init__.py 文件中讀取 version 參數(shù),來配置當(dāng)前軟件的版本,并指定了代碼包名(name)、作者(author)、郵箱(author_email)、描述信息(long_description、long_description_content_type)、依賴(install_requires),以及哪些文件不會(huì)被打包到程序中(exclude_package_data)。
另外需要提醒大家一點(diǎn), 給程序起名字不要帶下劃線(_) ,python import 代碼包時(shí),是不支持下劃線包名的,出現(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é)束后,會(huì)產(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]
上傳完畢!不過這里有一點(diǎn)需要注意,上傳新版本后,很可能 pip search 還沒法查到版本的更新,這是正常的,我理解是
pip search 命令依賴于緩存,所以不會(huì)立刻生效。
接下來就讓我們下載自己剛剛上傳的 python 試試吧:
$ pip install example-pkg $ python >>> import example-pkg >>> example-pkg.name 'example-pkg'
最后再補(bǔ)充一點(diǎn),上傳可能會(huì)失敗,提示無法上傳指定的代碼包,此時(shí)很大的可能是 pypi 中已經(jīng)有了相同的代碼包,所以建議在上傳之前,先搜索一下是否有重名的代碼包,選擇一個(gè)不沖突的名字,再上傳。
例如下面這個(gè)例子,example-pkg 已經(jīng)存在了,如果要再上傳,那當(dāng)然會(huì)失敗,換個(gè)名字就解決了。
$ pip search example-pkg example-pkg (0.0.7) - A small example package ......
5. 參考文檔
以上就是本文的全部內(nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
python從sqlite讀取并顯示數(shù)據(jù)的方法
這篇文章主要介紹了python從sqlite讀取并顯示數(shù)據(jù)的方法,涉及Python操作SQLite數(shù)據(jù)庫的讀取及顯示相關(guān)技巧,需要的朋友可以參考下2015-05-05
OpenCV停車場車位實(shí)時(shí)檢測項(xiàng)目實(shí)踐
本文主要介紹了OpenCV停車場車位實(shí)時(shí)檢測項(xiàng)目實(shí)踐,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-04-04
python定位xpath 節(jié)點(diǎn)位置的方法
今天小編就為大家分享一篇python定位xpath 節(jié)點(diǎn)位置的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2019-08-08
python3檢查字典傳入函數(shù)鍵是否齊全的實(shí)例
這篇文章主要介紹了python3檢查字典傳入函數(shù)鍵是否齊全的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧2020-06-06
Python實(shí)現(xiàn)線性擬合及繪圖的示例代碼
在數(shù)據(jù)處理和繪圖中,我們通常會(huì)遇到直線或曲線的擬合問題,本文主要介紹了Python實(shí)現(xiàn)線性擬合及繪圖的示例代碼,具有一定的參考價(jià)值,感興趣的可以了解一下2024-04-04
tensorflow使用tf.data.Dataset 處理大型數(shù)據(jù)集問題
這篇文章主要介紹了tensorflow使用tf.data.Dataset 處理大型數(shù)據(jù)集問題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12

