編程筆記9-編寫(xiě)python包并發(fā)布到pypi

pypi 賬號(hào)注冊(cè)

  1. 注冊(cè)

https://pypi.org/account/register

  1. 添加API tokens
    目前安全要求吝梅,上傳包不允許直接使用賬號(hào)密碼(以前是可以的厅克,網(wǎng)上大部分教程也是直接使用賬號(hào)密碼上傳)
添加API tokens

制作python包

做個(gè)簡(jiǎn)單的python庫(kù)兴泥,里面有四個(gè)文件,分別是setup.py抖剿、mypackage/__init__.pymypackage/mypackage.pyREADME.md

  1. setup.py
    setup.py 是庫(kù)的重點(diǎn)荚坞,里面詳細(xì)描述庫(kù)的信息墨闲,setuptools根據(jù)setup.py將庫(kù)打包今妄。

示例:

import os
from setuptools import setup
from setuptools import find_packages

with open(os.path.join(os.path.dirname(__file__), 'README.md')) as readme:
    README = readme.read()

VERSION = '0.1.1'

setup(
    name='mypackage',  # package name
    version=VERSION,  # package version
    description='mypackage description',
    author='wwdeng',
    author_email='xx@gmail.com',
    install_requires=['episcanpy==0.3.1','scanpy'],
    long_description=README,
    long_description_content_type='text/markdown',
    package_data={'': ['data/*']},    # 包的自帶數(shù)據(jù)
    classifiers=[
        'License :: OSI Approved :: MIT License',
        'Programming Language :: Python :: 3.10',
        'Programming Language :: Python :: 3.9',
        'Programming Language :: Python :: 3.8',
    ],
    packages=find_packages(),
    }
)

說(shuō)明:

  • version:這個(gè)簡(jiǎn)單,就是包的發(fā)布的版本鸳碧,可以直接寫(xiě)在這盾鳞,也可以從其他地方引用過(guò)來(lái)。
  • long_description:必須是rst(reStructuredText )格式的瞻离,因?yàn)檫@個(gè)里面的內(nèi)容是顯示在pypi包首頁(yè)上腾仅,我的long_description是同目錄下的README.rst的內(nèi)容,同時(shí)這個(gè)README也是我的github項(xiàng)目首頁(yè)套利。
  • packages:申明你的包里面要包含的目錄推励,比如 ['mypackage', 'mypackage_test'] 可以是這種使用我的示例,讓setuptools自動(dòng)決定要包含哪些包
  • install_requires:申明依賴(lài)包肉迫,安裝包時(shí)pip會(huì)自動(dòng)安裝:格式如下(我上面的setup.py沒(méi)有這個(gè)參數(shù)验辞,因?yàn)槲也灰蕾?lài)第三方包:)):

【推薦】大名鼎鼎的requests庫(kù)的作者大神kennethreitz為大家準(zhǔn)備了一個(gè)倉(cāng)庫(kù)作為一個(gè)setup.py的很好的模板:https://github.com/kennethreitz/setup.py

  1. mypackage/__init__.py

__init__.py表明mypackage是個(gè)包

name="mypackage"
  1. mypackage/mypackage.py
    mypackage/mypackage.py僅為一個(gè)示例,實(shí)際中所有包里面的函數(shù)都可以放在mypackage文件夾下
  1. README.md

README.md 用于描述這個(gè)庫(kù)喊衫,在setup.py做為長(zhǎng)描述使用


打包上傳

  1. 安裝必要的打包工具庫(kù)
pip install setuptools wheel twine

setuptools 是打包工具, 是 distutils 增強(qiáng)版跌造,不包括在標(biāo)準(zhǔn)庫(kù)中。其擴(kuò)展了很多功能族购,能夠幫助開(kāi)發(fā)者更好的創(chuàng)建和分發(fā) Python 包壳贪。大部分 Python 用戶(hù)都會(huì)使用更先進(jìn)的 setuptools 模塊。

wheel 庫(kù)安裝后可以打包成whl的包联四。Egg 格式是由 setuptools 在 2004 年引入撑碴,而 Wheel 格式是由 PEP427 在 2012 年定義。Wheel 的出現(xiàn)是為了替代 Egg朝墩,它的本質(zhì)是一個(gè)zip包醉拓,其現(xiàn)在被認(rèn)為是 Python 的二進(jìn)制包的標(biāo)準(zhǔn)格式伟姐。

  1. 將編寫(xiě)的庫(kù)安裝測(cè)試一下是否正常
python setup.py develop
  1. 打包
# 在當(dāng)前目錄的dist文件夾下,生成一個(gè)以tar.gz結(jié)尾的包
python setup.py sdist build

# 在dist文件夾下生成一個(gè)whl格式的包
python setup.py bdist_wheel --universal
  1. 上傳

twine 用于上傳包到pypi

twine upload dist/*

參考

https://blog.csdn.net/dreamblog/article/details/132659002
https://codeantenna.com/a/uEd3D2itku
https://github.com/kennethreitz/setup.py/blob/master/setup.py

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末亿卤,一起剝皮案震驚了整個(gè)濱河市愤兵,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌排吴,老刑警劉巖秆乳,帶你破解...
    沈念sama閱讀 206,013評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異钻哩,居然都是意外死亡屹堰,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,205評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén)街氢,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)扯键,“玉大人,你說(shuō)我怎么就攤上這事珊肃∪傩蹋” “怎么了?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,370評(píng)論 0 342
  • 文/不壞的土叔 我叫張陵伦乔,是天一觀的道長(zhǎng)厉亏。 經(jīng)常有香客問(wèn)我,道長(zhǎng)烈和,這世上最難降的妖魔是什么爱只? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,168評(píng)論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮斥杜,結(jié)果婚禮上虱颗,老公的妹妹穿的比我還像新娘。我一直安慰自己蔗喂,他們只是感情好忘渔,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,153評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布。 她就那樣靜靜地躺著缰儿,像睡著了一般畦粮。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上乖阵,一...
    開(kāi)封第一講書(shū)人閱讀 48,954評(píng)論 1 283
  • 那天宣赔,我揣著相機(jī)與錄音,去河邊找鬼瞪浸。 笑死儒将,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的对蒲。 我是一名探鬼主播钩蚊,決...
    沈念sama閱讀 38,271評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼贡翘,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了砰逻?” 一聲冷哼從身側(cè)響起鸣驱,我...
    開(kāi)封第一講書(shū)人閱讀 36,916評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎蝠咆,沒(méi)想到半個(gè)月后踊东,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,382評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡刚操,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,877評(píng)論 2 323
  • 正文 我和宋清朗相戀三年闸翅,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片赡茸。...
    茶點(diǎn)故事閱讀 37,989評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡缎脾,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出占卧,到底是詐尸還是另有隱情,我是刑警寧澤联喘,帶...
    沈念sama閱讀 33,624評(píng)論 4 322
  • 正文 年R本政府宣布华蜒,位于F島的核電站,受9級(jí)特大地震影響豁遭,放射性物質(zhì)發(fā)生泄漏叭喜。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,209評(píng)論 3 307
  • 文/蒙蒙 一蓖谢、第九天 我趴在偏房一處隱蔽的房頂上張望捂蕴。 院中可真熱鬧,春花似錦闪幽、人聲如沸啥辨。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,199評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)溉知。三九已至,卻和暖如春腕够,著一層夾襖步出監(jiān)牢的瞬間级乍,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,418評(píng)論 1 260
  • 我被黑心中介騙來(lái)泰國(guó)打工帚湘, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留玫荣,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 45,401評(píng)論 2 352
  • 正文 我出身青樓大诸,卻偏偏與公主長(zhǎng)得像捅厂,于是被迫代替她去往敵國(guó)和親材诽。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,700評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容