Python 项目代码写完了,然后怎么打包和发布?

学习python的正确姿势

共 1749字,需浏览 4分钟

 ·

2020-07-24 07:11


你把你的代码写完了,是不是要给别人使用下,怎么打包你的项目代码呢?
喂,开源么?


320009850b5f40242e766814ccf718b2.webp

接下来小帅b就跟你说说,如何打包你的代码。

就拿我们上次演示的 todo 为例,写完代码之后,代码的目录是这样的:


13b59c93ae779c55efa207001e05882b.webp



在 todo 这个目录里面,文件都放在一起了,我们可以这样简单划分一下:



bb4b93f66a2203d5a52aa58d556512ed.webp




这里创建了一个 package 目录,将源码文件放进去,然后把模板文件和数据库文件分门别类的安排好。
在 package 中,还创建了一个 __init__.py 仪式感一下。
为了让别人知道你是认真对待这个项目的,你可以在项目文件中创建一个 tests 目录,在里面测试你的代码:



10573b7a9ac5ff8682a77f99a168f325.webp




接着可以创建一个 LICENSE ,用来说明你的这个项目可以被怎么使用?是不是需要声明来源,是不是可以商用?别人用你的项目去搞事情如何避免被抓去吃牢饭等。

现成的开源协议有好几种,不太了解的可以看看我之前写的这个:那些 GitHub 所声明的开源协议都是什么意思


2119ea6a8362cf6198375cb31ab76b2e.webp



接着再创建一个 README 文件,来说明你这个项目是干什么的,如何使用等描述。


141849dc92f45e7d79d17afde2b93d58.webp



现在你的项目文件目录就有点人模人样了:



4d528c1376fe7abb20d60a857ef874c5.webp




接下来要创建一个比较重要的文件了 —— setup.py,这个文件主要用来描述你的项目信息,好让 setuptools 打包工具来帮你打包项目。
在根目录下创建一个 setup.py 文件,按以下的方式来写你的项目信息:

dfe612d6e30ef10aaf7920299e1181e8.webp




每个参数都是什么意思呢?我来给你说明一下:

long_description:对项目比较长的描述,我们可以直接从 你刚刚写的 README 文件读取。


a84146761dc2aa7023d45bf573c8c891.webp




name: 你定义的包名,可以用字母、数字、下划线,需要确保唯一性。
version: 项目的版本号。

author: 你(作者)的名称。
author_email: 你(作者) 的邮箱。
description: 项目的简要描述。
long_description_content_type:长描述内容的使用的标记类型,一般为 markdown 或者 rst。
url: 你这个项目的主页地址,也可以直接链接到你这个项目的Github 地址上面去。
include_package_data: 是否添加 py 以外的文件。
package_data: 需要添加 Python 的额外文件列表。
packages: 直接用 setuptool 找到你项目所有相关的包列表。
classifiers: 附加说明,比如这里写的就是使用于 Python3 版本,使用的是 MIT 协议,独立于 OS。
python_requires: python 版本要求。
那么现在,你的项目目录应该是这样子的:


887e3a9cd04de9b7642fd566a81e5460.webp




接下来就可以打包了。

如果你之前没有安装过 setuptools 和 wheel 可以先安装一波:

python3 -m pip install --upgrade setuptools wheel

66840d98ee13d48a1d97a50e8049e06c.webp



然后在你的项目根目录下,使用如下命令打包:

python3 setup.py sdist bdist_wheel

f7cc9d405dc3cd8b519ca6940452f07a.webp



这时候你的目录会增加这么些文件:


d5d7f2ff235b14b2eb6e5e317c23ab92.webp



这样就算打包好了,在 dist 目录中,以 tar.gz 结尾的是你项目的源文件,而以 .whl 结尾的就是构建好了给别人使用的发行版。

那么如何将你打包好的项目发布出来,给别人使用呢?
其实之前有说过了,这里再简单的说一下吧:
先安装一下 twine:
python3 -m pip install twine
接着使用 twine 将你打包好的文件上传到 pypi 上面去:
twine upload dist/*
这时候它会提示你输入 pypi 的账号密码:

5ee79ed5a8ad5c4e762d640881352650.webp



没有怎么办?去注册一个呗,到以下链接注册:https://pypi.org/account/register/
接着输入你的账号密码,就可以上传上去了:


ca3509cbb8b0b01ff22d54da59f108b6.webp



这时候别人就可以通过 pip 来安装你的项目了:

70c7dc6f75af5a9cf23149c71cc12d04.webp

50d05eddc0e96f37446ca2dba6c354e1.webp



像这样:


a75277d4048ccf99abc7277f8d7bb8ee.webp



然后就可以给别人使用你的包了:


11c5809a19c11b09642fde942847de3e.webp



你在 pip install 的时候,其实就是下载你上传的 whl 文件然后安装:


a75277d4048ccf99abc7277f8d7bb8ee.webp

如果你不想开源,只想给你朋友使用的话,你也可以直接把 dist 这个目录下的文件发给他,让他自行安装一波就可以使用了:

d18b9aa0e9c81ceaa00e1663811edce1.webp

1b95670af1a784c43aab1fb2a58c0026.webp



ok,以上就是今天小帅b给你带来的分享,希望对你有帮助,那么我们下回见,peace!


d551aa2803da1649cd2c4c09e219864a.webp

扫一扫

学习 Python 没烦恼



浏览 42
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报
评论
图片
表情
推荐
点赞
评论
收藏
分享

手机扫一扫分享

分享
举报