手把手教你發佈一個Python包

本文主題如下:

編寫一個包(Python 源代碼),但不是本文的重點。

編譯包,觀察編譯後的文件。

發佈包,發佈的包可以有多種類型。

如何在 Pypi 中查看已發佈的包

注意:

本文編寫的包在 Python2 環境下測試通過,實際上這個包(只是個例子)比較簡單,在 Python3 下也能運行。

本文知識點可能陳舊,比如 Python Pypi 官方已做了很大改變。

1. 編寫包源代碼

這篇文章主要描述如何發佈一個包,不描述如何編寫一個包,如果你沒有代碼(只想學習如何發佈包),可下載下面的示例。

$ wget "https://files.pythonhosted.org/packages/96/66/43e6df87373557553be2b4343db27d008c6dcefa110ccff38cba1459ca07/ywdblogmath-0.1.tar.gz"

2. 查看 setup.py

爲了生成和發佈包,必須編寫 setup.py 文件,編寫該文件必須依賴於 setuptools 包,這個包本身也是一個 Python 包。.

#!/usr/bin/env python
from setuptools import setup
setup(name='ywdblogmath',
    version='0.1',
    description='A silly ywdblogmath package',
    author='ywdblog',
    author_email='[email protected]',
    url='http://www.yudadan.com/',
    packages=['ywdblogmath', 'ywdblogmath.adv'],
)

望文生義,不過多講解相應的參數。

3. 測試本地包

首先將該代碼生成一個本地包,然後編寫代碼測試該包的功能。

在開發模式下安裝包:

$ python setup.py develop

觀察安裝後生成的文件:

/usr/local/lib/python2.7/dist-packages/ywdblogmath.egg-link

/usr/local/lib/python2.7/dist-packages/easy-install.pth

這二個文件包含的內容就是 /root/python(一個軟連接)。

編寫測試文件 example.py :

import sys
import ywdblogmath
print(ywdblogmath.add(4,5))
print(ywdblogmath.division(4, 2))
print(ywdblogmath.multiply(10, 5))
print(ywdblogmath.squareroot(48))

然後運行 example.py:

$ python  example.py
    9
    2
    50
    6.92820323028.

4. 配置 pypi

(1)爲了發佈包,必須在 pypi.org 註冊一個用戶,註冊郵箱需要驗證。
(2)配置 $HOME”.pypirc” 文件:

[distutils]
index-servers=pypi
[pypi]
repository = https://upload.pypi.org/legacy/
username = pypi.org 登錄名
password = pypi.org 登陸密碼

5. 發佈包

在發佈包之前,運行下列命令瞭解所有可用的命令:

$ python setup.py --help-commands

先編譯包:

$ python setup.py build

運行完成後生成 /root/python/build 目錄,所以編譯的文件保存在該目錄下。

(1)生成 tar.gz 包

$ python setup.py sdist

運行後產生下列文件:

/root/python/dist/ywdblogmath-0.1.tar.gz
/root/python/ywdblogmath.egg-info (python setup.py egg_info 命令也會生成該文件)

(2)生成 egg 包

$ python setup.py bdist_egg

運行後產生下列文件:

/root/python/dist/ywdblogmath-0.1-py2.7.egg
/root/python/ywdblogmath.egg-info (python setup.py egg_info 命令也會生成該文件)

(3)生成 wheel 包

$ python setup.py bdist_wheel

運行後產生下列文件:

/root/python/dist/ywdblogmath-0.1-py2-none-any.whl
/root/python/ywdblogmath.dist-info

最後發佈包(任何一個命令都可以):

# 發佈 .tar.gz 包
$ python setup.py sdist upload 
# 發佈 egg 包
$ python setup.py bdist_egg upload 
# 發佈 wheel 包
$ python setup.py bdist_wheel upload

至於發佈什麼類型的包,讀者自己決定,如果想讓所有的包安裝工具(比如 pip、easy_install )都能安裝你發佈的包,可同時發佈這三種類型的包。

登錄 pypi.org 查看發佈的包

在發佈包的時候,可能會遇到很多命令行提示的錯誤,這些內容不是本文的重點,另外注意 setpy.py 中的包版本號,可以測試發佈多版本的包。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章