欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

將自己的Python包發(fā)布到PyPI上的教程詳解

 更新時(shí)間:2023年09月11日 10:23:04   作者:Python數(shù)據(jù)開(kāi)發(fā)  
在Python中我們經(jīng)常使用pip來(lái)安裝第三方Python軟件包,其實(shí)我們每個(gè)人都可以免費(fèi)地將自己寫(xiě)的Python包發(fā)布到PyPI上,本文小編就來(lái)教教大家如何將自己的Python包發(fā)布到PyPI上吧

1. PyPi的用途

Python中我們經(jīng)常會(huì)用到第三方的包,默認(rèn)情況下,用到的第三方工具包基本都是從Pypi.org里面下載。

我們舉個(gè)栗子: 如果你希望用Python實(shí)現(xiàn)一個(gè)金融量化分析工具,目前比較好用的金融數(shù)據(jù)來(lái)源是 Yahoo 和 Google。你可能需要讀取這 2 個(gè)平臺(tái)的 API,然后依次實(shí)現(xiàn)下載、分析數(shù)據(jù)的代碼。是不是好麻煩,這樣你可以到 PyPi 到上面去找找有沒(méi)有已經(jīng)寫(xiě)過(guò)這個(gè)內(nèi)容,幸運(yùn)的是,你真找到了,你找到了一個(gè) package 叫做 yfinance。

https://github.com/ranaroussi/yfinance

這個(gè)時(shí)候你只需要一個(gè)命令,免除了我們從頭實(shí)現(xiàn)的麻煩:

pip install yfinance

就可以了,是不是非常方便。

PyPI 是 Python Package Index 的首字母簡(jiǎn)寫(xiě),其實(shí)表示的是 Python 的 Packag 索引,這個(gè)也是 Python 的官方索引。

需要先再本地環(huán)境安裝pip,然后如果要安裝其他工具包的話就使用指令:

pip install <package name>

官方地址:https://pypi.org/

一句話解釋:如果你使用的是 Java 項(xiàng)目的話,你就將 PyPi 理解成 Maven 就行了。

那我們?nèi)绾螌⒆约洪_(kāi)發(fā)的一個(gè)包上傳到PyPI,供其它人使用呢。

2.Python包發(fā)布步驟

下面就開(kāi)始介紹如何將自己的Python項(xiàng)目發(fā)布到PyPI

2.1 創(chuàng)建目錄結(jié)構(gòu)

創(chuàng)建一個(gè)測(cè)試項(xiàng)目,例如project_demo,在該項(xiàng)目下,創(chuàng)建一個(gè)待發(fā)布的包目錄,例如:package_mikezhou_talk,并在該project_demo目錄下,依次創(chuàng)建:setup.py、LICENSE、README.rst幾項(xiàng)文件,此時(shí)目錄結(jié)構(gòu)為:

?  project_demo tree -L 2
.
├── LICENSE
├── README.rst
├── package_mikezhou_talk
│   └── __init__.py
└── setup.py
1 directory, 4 files

2.2 準(zhǔn)備文件

接下來(lái)我們來(lái)逐一編寫(xiě)除了代碼以外的文件。

1、README.rst是關(guān)于項(xiàng)目的描述文件,一般包含怎樣安裝項(xiàng)目,怎樣使用項(xiàng)目等。markdown 語(yǔ)法可以參考 https://rest-sphinx-memo.readthedocs.io/en/latest/ReST.html

打開(kāi)README.rst并輸入以下內(nèi)容。可以自定義此項(xiàng),放入一些對(duì)項(xiàng)目的介紹。

# Example Package
This is a simple example package. You can use
to write your content.

2、LICENSE.txt,創(chuàng)建許可證

上傳到Python Package Index的每個(gè)包都包含許可證,這一點(diǎn)很重要。這告訴用戶安裝你的軟件包可以使用您的軟件包的條款。開(kāi)源License,有如MIT,Apache license 2.0等。有關(guān)選擇許可證的幫助,請(qǐng)?jiān)L問(wèn)https://choosealicense.com/。選擇許可證后,打開(kāi) LICENSE并輸入許可證文本。

3、setup.py文件

setup.py是setuptools的構(gòu)建腳本,用來(lái)描述項(xiàng)目,打包的時(shí)候會(huì)用到這個(gè)文件。它告訴PyPI我們的項(xiàng)目叫什么名字,是什么版本,依賴哪些庫(kù),支持哪些操作系統(tǒng),可以在哪些版本的Python上運(yùn)行,等等。

from distutils.core import setup
from setuptools import find_packages
with open("README.rst", "r") as f:
  long_description = f.read()
setup(name='package_mikezhou_talk',  # 包名
      version='1.0.0',  # 版本號(hào)
      description='A small example package',
      long_description=long_description,
      author='mike_talk',
      author_email='762357658@qq.com',
      url='',
      install_requires=[],
      license='BSD License',
      packages=find_packages(),
      platforms=["all"],
      classifiers=[
          'Intended Audience :: Developers',
          'Operating System :: OS Independent',
          'Natural Language :: Chinese (Simplified)',
          'Programming Language :: Python',
          'Programming Language :: Python :: 2',
          'Programming Language :: Python :: 2.7',
          'Programming Language :: Python :: 3',
          'Programming Language :: Python :: 3.5',
          'Programming Language :: Python :: 3.6',
          'Programming Language :: Python :: 3.7',
          'Programming Language :: Python :: 3.8',
          'Topic :: Software Development :: Libraries'
      ],
      )

重要參數(shù)說(shuō)明:

name:項(xiàng)目的名稱,name是包的分發(fā)名稱。

version:項(xiàng)目的版本。需要注意的是,PyPI上只允許一個(gè)版本存在,如果后續(xù)代碼有了任何更改,再次上傳需要增加版本號(hào)

author和author_email:項(xiàng)目作者的名字和郵件, 用于識(shí)別包的作者。

description:項(xiàng)目的簡(jiǎn)短描述

long_description:項(xiàng)目的詳細(xì)描述,會(huì)顯示在PyPI的項(xiàng)目描述頁(yè)面。必須是rst(reStructuredText) 格式的

packages:指定最終發(fā)布的包中要包含的packages。

install_requires:項(xiàng)目依賴哪些庫(kù),這些庫(kù)會(huì)在pip install的時(shí)候自動(dòng)安裝

classifiers:其他信息,一般包括項(xiàng)目支持的Python版本,License,支持的操作系統(tǒng)。

克隆setup.py倉(cāng)庫(kù)(推薦)

如果你覺(jué)得手寫(xiě)setup.py腳本文件難度大太,給你推薦另外一個(gè)簡(jiǎn)易方法。

大名鼎鼎的requests庫(kù)的作者大神kennethreitz為大家準(zhǔn)備了一個(gè)倉(cāng)庫(kù)作為一個(gè)setup.py的很好的模板,當(dāng)然你也可以自己手寫(xiě)setup.py。

git clone  https://github.com/kennethreitz/setup.py

建議大家直接編輯之前的倉(cāng)庫(kù)里的setup.py, 只需要修改一些必要的配置就可以了。

2.3 編寫(xiě)核心代碼

接下來(lái)我們就可以編寫(xiě)自己的代碼了,要注意源代碼文件夾(倉(cāng)庫(kù)里的package_mikezhou_talk包目錄)的名字與setup.py里配置的包名(Name)要一致。

這一部?jī)?nèi)容,就根據(jù)各自的需求,自行實(shí)現(xiàn)即可。例如:我在示例package_mikezhou_talk包目錄下,新建了一個(gè)main.py文件,在該文件下實(shí)現(xiàn)待實(shí)現(xiàn)的功能。

示例:

import itertools
case_list = ['用戶名', '密碼']
value_list = ['正確', '不正確', '特殊符號(hào)', '超過(guò)最大長(zhǎng)度']
def gen_case(item=case_list, value=value_list):
    '''輸出笛卡爾用例集合'''
    for i in itertools.product(item, value):
        print('輸入'.join(i))
def test_print():
     print("歡迎搜索關(guān)注公眾號(hào): 「測(cè)試開(kāi)發(fā)技術(shù)」!")
if __name__ == '__main__':
    test_print()

2.4 生成分發(fā)檔案

下一步是為包生成分發(fā)包。這些是上傳到包索引的檔案,可以通過(guò)pip安裝。

確保您擁有setuptools并wheel 安裝了最新版本:

python3 -m pip install --user --upgrade setuptools wheel

生成這前,可以先運(yùn)行python setup.py check檢查setup.py是否有錯(cuò)誤,如果沒(méi)報(bào)錯(cuò)誤,則進(jìn)行下一步輸出一般是running check。

1、準(zhǔn)備好上面的步驟, 一個(gè)包就基本完整了, 剩下的就是打包了,可以使用下面命令打包一個(gè)源代碼的包:

python setup.py sdist build

這樣在當(dāng)前目錄的dist文件夾下, 就會(huì)多出一個(gè)tar.gz結(jié)尾的包了:

2、也可以打包一個(gè)wheels格式的包, 使用下面的命令就可以了:

python setup.py bdist_wheel --universal

這樣會(huì)在dist文件夾下面生成一個(gè)whl文件.

3、或者從setup.py位于的同一目錄運(yùn)行此命令:

python3 setup.py sdist bdist_wheel

上面的命令會(huì)在dist目錄下生成一個(gè)tar.gz的源碼包和一個(gè).whl的Wheel包。

2.5 發(fā)布包到PyPi

1、接下來(lái)就是去https://pypi.org/account/register/注冊(cè)賬號(hào),如果有賬號(hào)的請(qǐng)忽略,記住你的賬號(hào)和密碼,后面上傳包會(huì)使用。

2、接下來(lái)就是上傳你的包了,這里使用twine上傳。需要先安裝twine(用 twine上傳分發(fā)包,并且只有 twine> = 1.11.0 才能將元數(shù)據(jù)正確發(fā)送到 Pypi上)

pip install twine

3、安裝完之后,運(yùn)行下面的命令將庫(kù)上傳,上傳包,期間會(huì)讓你輸入注冊(cè)的用戶名和密碼

twine upload dist/*

輸入 PyPI注冊(cè)的用戶名和密碼。命令完成后,您應(yīng)該看到與此類似的輸出:

?  twine upload dist/*
Uploading distributions to https://upload.pypi.org/legacy/
Enter your username: mikezhou_talk
Enter your password:
Uploading package_mikezhou_talk-1.0.0-py3-none-any.whl
100%|██████████████████████████████████████| 7.84k/7.84k [00:03<00:00, 2.29kB/s]
Uploading package_mikezhou_talk-1.0.0.tar.gz
100%|██████████████████████████████████████| 6.64k/6.64k [00:01<00:00, 6.05kB/s]
View at:
https://pypi.org/project/package-mikezhou-talk/1.0.0/

上傳完成后,我們的項(xiàng)目就成功地發(fā)布到PyPI了。

3.驗(yàn)證發(fā)布PYPI成功

上傳完成了會(huì)顯示success,我們直接可以在PyPI上查看,如下:

您可以使用pip來(lái)安裝包并驗(yàn)證它是否有效。創(chuàng)建一個(gè)新的virtualenv (請(qǐng)參閱安裝包以獲取詳細(xì)說(shuō)明)并從TestPyPI安裝包:

python3 -m pip install --index-url https://test.pypi.org/simple/ package-mikezhou-talk

pip install package-mikezhou-talk -i https://www.pypi.org/simple/

如下圖所示:

進(jìn)入Python Shell驗(yàn)證結(jié)果如下:

至此,我們已經(jīng)成功地將自己開(kāi)發(fā)的Python程序發(fā)布到了PyPI,此時(shí)你,可以直接在你本地的環(huán)境通過(guò)pip命令安裝示例中的package-mikezhou-talk這個(gè)包了。

官網(wǎng)地址:

https://pypi.org/project/package-mikezhou-talk/1.0.0/

以上就是將自己的Python包發(fā)布到PyPI上的教程詳解的詳細(xì)內(nèi)容,更多關(guān)于Python PyPI的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 利用django如何解析用戶上傳的excel文件

    利用django如何解析用戶上傳的excel文件

    這篇文章主要給大家介紹了關(guān)于利用django如何解析用戶上傳的excel文件的相關(guān)資料,這是最近在工作中遇到的一個(gè)問(wèn)題,覺(jué)著有必要分享出給大家,需要的朋友可以參考借鑒,下面來(lái)一起看看詳細(xì)的介紹吧。
    2017-07-07
  • Python 代碼實(shí)現(xiàn)各種酷炫功能

    Python 代碼實(shí)現(xiàn)各種酷炫功能

    這篇文章主要介紹了Python 代碼實(shí)現(xiàn)各種酷炫功能,生成二維碼、生成詞云、批量摳圖、文字情緒識(shí)別等功能分享,需要的小伙伴可以參考一下
    2022-03-03
  • Python如何查看并打印matplotlib中所有的colormap(cmap)類型

    Python如何查看并打印matplotlib中所有的colormap(cmap)類型

    這篇文章主要介紹了Python如何查看并打印matplotlib中所有的colormap(cmap)類型,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-11-11
  • Python 使用SMOTE解決數(shù)據(jù)不平衡問(wèn)題(最新推薦)

    Python 使用SMOTE解決數(shù)據(jù)不平衡問(wèn)題(最新推薦)

    SMOTE是一種強(qiáng)大的過(guò)采樣技術(shù),可以有效地處理不平衡數(shù)據(jù)集,提升分類器的性能,通過(guò)imbalanced-learn庫(kù)中的SMOTE實(shí)現(xiàn),我們可以輕松地對(duì)少數(shù)類樣本進(jìn)行過(guò)采樣,平衡數(shù)據(jù)集,這篇文章主要介紹了Python 使用SMOTE解決數(shù)據(jù)不平衡問(wèn)題,需要的朋友可以參考下
    2024-05-05
  • 將pandas.dataframe的數(shù)據(jù)寫(xiě)入到文件中的方法

    將pandas.dataframe的數(shù)據(jù)寫(xiě)入到文件中的方法

    今天小編就為大家分享一篇將pandas.dataframe的數(shù)據(jù)寫(xiě)入到文件中的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-12-12
  • Python pygame 動(dòng)畫(huà)游戲循環(huán)游戲時(shí)鐘實(shí)現(xiàn)原理

    Python pygame 動(dòng)畫(huà)游戲循環(huán)游戲時(shí)鐘實(shí)現(xiàn)原理

    這篇文章主要為大家介紹了Python pygame 動(dòng)畫(huà)游戲循環(huán)游戲時(shí)鐘實(shí)現(xiàn)原理詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • python3中bytes和string之間的互相轉(zhuǎn)換

    python3中bytes和string之間的互相轉(zhuǎn)換

    這篇文章主要介紹了python3中bytes和string之間的互相轉(zhuǎn)換,文中給出了詳細(xì)的介紹和示例代碼,相信對(duì)大家具有一定的參考價(jià)值,有需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。
    2017-02-02
  • python爬蟲(chóng)數(shù)據(jù)保存到mongoDB的實(shí)例方法

    python爬蟲(chóng)數(shù)據(jù)保存到mongoDB的實(shí)例方法

    在本篇文章里小編給大家整理的是一篇關(guān)于python爬蟲(chóng)數(shù)據(jù)保存到mongoDB的實(shí)例方法,有需要的朋友們可以參考下。
    2020-07-07
  • 基于python實(shí)現(xiàn)查詢ip地址來(lái)源

    基于python實(shí)現(xiàn)查詢ip地址來(lái)源

    這篇文章主要介紹了基于python實(shí)現(xiàn)查詢ip地址來(lái)源,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-06-06
  • Python socket處理client連接過(guò)程解析

    Python socket處理client連接過(guò)程解析

    這篇文章主要介紹了Python socket處理client連接過(guò)程解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-03-03

最新評(píng)論