构建并发布你的自定义 Python 包(创建自定义函数python)
off999 2025-07-02 23:51 29 浏览 0 评论
Python 让你可以重用代码,并将代码分享给他人以节省时间和精力。所以,当你编写了一些方便的脚本,希望你的同事或其他人也能使用时,接下来该怎么做呢?这篇文章就来解决打包和分发的问题。我们将专注于将你的代码转换为一个 Python 包,以便人们能够轻松安装。
读完这篇文章后,你将能够:
- 了解 Python 包的要求
- 构建一个 Python 包,或者将现有项目转换为一个包
- 使用 pip 安装自己构建的包
一、为什么要构建 Python 包?
想象一下,每次你想解析某种特定格式的文件时,都得从头开始编写代码。你将永远无法完成任何事情!包是编程中的基本构建块。如果没有包,我们将花费大量时间编写已经有人写过的代码。这就是我们总是想要使用包的原因。包是 Python 中层级命名空间概念的体现。
引用《Python 之禅》中的一句话:
“命名空间是个绝妙的主意——让我们多用用!”
如果你想查看完整的《Python 之禅》,可以在 Python 代码单元中输入 `import this`。
这行代码 import this 是一个彩蛋导入语句。在Python中,当你导入this模块时,它会自动打印出"The Zen of Python"(Python之禅),这是由Tim Peters编写的一组Python设计原则和哲学。
即使你从未打算将代码分享给他人,一个结构良好的包也能简化开发过程。
二、构建你自己的 Python 包
现在是时候将你的代码打包了。以下是构建你自己的包需要了解的基本内容。
基本结构:
让我们逐一了解这些文件:
- 包名(例如:calculator):创建一个与你的包同名的文件夹。在我的例子中,这是一个名为“calculator”的文件夹。这就是我们要安装的包。将你想要发布的文件和类都放入这个文件夹中。包名应尽量简短,全部使用小写字母。除非有助于提高可读性,否则不建议在包名中使用下划线。
- __init__.py:这个文件让 Python 知道我们创建的目录是一个包,文件名没有灵活性。如果你删除了 __init__.py 文件,Python 将不再在该目录中查找子模块,因此尝试导入模块将会失败。__init__.py 文件通常为空,但也可以用于导出包中选定的部分,以便使用更方便的名称,或者包含一些便利函数等。
- tests:每个人都会犯错,这就是为什么铅笔有橡皮擦,电脑有拼写检查,而我们的代码需要测试。我们相信代码能够运行,但必须进行验证。测试文件通常放在一个单独的目录中。
- license:在当今技术世界中,许可证非常常见。有许多不同类型的法律文件可以用来保护你的代码。在创建 Python 包时,有时需要许可证,但无论如何,拥有许可证总是一个好习惯。对于这个示例项目,我使用了MIT 许可证。如果你不确定选择哪种许可证,可以参考 GitHub 提供的选择许可证资源。
- README.md:你的 Python 包应该始终有一个编写良好的 README 文件,因为它不仅展示了项目的质量,还提供了易于阅读和访问的信息。
- setup.py:这个文件告诉 pip 如何安装我们的实际包。它包含对“setuptools”包中的 setup 函数的单一调用。Setuptools 是最常见且功能强大的工具之一。
- name:你的包在 PyPI 上显示的名称。
- version:你的包的当前版本。对于版本号,有许多不同的方案可供选择。对于简单的项目,语义化版本控制 是一个很好的默认选择。例如,我们示例项目的版本号是:0.0.1。
- packages:该参数接受一个包的列表。在我们的例子中,只有一个包:calculator。在较大的项目中,可能会有很多包需要列出。为了简化这个任务,setuptools 提供了一个功能find_packages(),它可以很好地发现你所有的子包。
三、将 Python 包上传到 PyPI
现在你的代码已经打包完成,准备好向全世界展示啦!如果你能坚持到这里,那就给自己点个赞吧,你已经取得了很大的进展,离成功只差一步之遥了!:)。在这一部分,你将看到如何将你的包实际上传到 PyPI。
首先,你需要在 PyPI 上注册一个账号。如果你还没有账号,现在是注册的好时机。你可以在这里注册 PyPI 账号。记得记下你的用户名(注意:不是名字,也不是邮箱地址)和密码,稍后上传过程中会用到。
四、最后步骤
打开存储所有包信息的文件夹的命令提示符。例如:
cd "C://PATH//TO//YOUR//FOLDER"接下来,我们将使用一个名为 Twine 的工具。你可以通过 pip 安装 Twine:
pip install twinePyPI 上的包并不是以纯源代码的形式分发的。相反,它们被封装成分发包。最常见的分发包格式是源码归档和 Python wheels。
Python wheels 是什么
Python wheels 是一种预构建的包分发格式,是 Python 包安装和分发的现代标准。
wheels 的主要特点
- 文件格式:.whl 扩展名,本质上是一个 ZIP 压缩文件
- 预编译:包含已编译好的二进制文件,不需要在安装时进行编译
- 快速安装:比传统的源码分发包(sdist)安装速度更快
- 命名规范:遵循 {包名}-{版本}-{构建标签}-{Python标签}-{ABI标签}-{平台标签}.whl 格式
wheels 与 sdist 的比较
- wheels:预构建的二进制分发包,直接安装使用
- sdist:源代码分发包,安装时需要在用户环境中编译
要为你的包创建一个源码归档和一个wheel,我们可以运行以下命令:
python setup.py bdist_wheel现在,终于到了你期待已久的时刻,再执行最后一个命令:
twine upload dist/*记得在提示时输入你的用户名和密码,就这样!恭喜你成功上传了第一个 Python 包,访问
https://pypi.org/project/your-package-name/ 查看你的包在 PyPI 上的页面。
五、使用 pip 在 PyPI 上安装你的自定义包
看到自己的代码通过 pip 安装是一种美妙的体验!想试试吗?你可以通过以下命令安装你刚刚上传到 PyPI 的包:
pip install your-python-package从 GitHub 使用 pip 安装你的自定义包
另外,你也可以直接从 GitHub 使用 pip 安装代码。
创建一个仓库并将所有代码文件推送到该仓库(就像我们之前做的一样)。
复制仓库的 URL,然后通过以下命令安装:
pip install git+https://github.com/username/your-awesome-package.git这篇文章为你介绍了 Python 包的构建、上传到 PyPI 的原因、过程和方法。
相关推荐
- win11 16g内存最佳虚拟内存(window10 16个g虚拟内存设置)
-
内存足够大可以将系统的虚拟内存关掉。1、鼠标右键【此电脑】,在菜单中选择【属性】。2、进入属性后,点击【高级系统设置】。3、进入系统属性后,点击高级下面的【设置】。4、进入性能设置后,点击【高级】。5...
- 查看windows7激活码(win7激活码哪里看)
-
windows7激活密钥如下:PPBK3-M92CH-MRR9X-34Y9P-7CH2FQ8JXJ-8HDJR-X4PXM-PW99R-KTJ3H8489X-THF3D-BDJQR-D27PH-P...
- win10商业版和消费者版区别(win10商业版与消费者版)
-
1、用户群体的区别消费者版:通俗来说就是零售版,是一个非常适合个人用户和家庭用户购买的版本。商业版:适合大客户使用的版本,而且还比较适合企业用户使用以及进行批量部署。2、版本区别消费者版Consume...
- bilibili加速器(bilibili加速器手机版官网)
-
需要在电脑上使用bilibili加速器,因为手机上bilibili已经有自带的加速器功能了。可以在bilibili官网或者一些应用商店下载使用,下完后按照安装提示进行安装即可。如果使用的是第三方软件,...
- 电脑自带的清理垃圾的工具(电脑自带的清理垃圾的工具叫什么)
-
CCleaner是一款免费的系统优化和隐私保护工具,它的体积小、扫描速度非常快,支持自定义清理规则,增强了应用程序清理范围和效果。CCleaner是Piriform(梨子公司)最著名广受好评的系统清理...
- 如何设置本地连接
-
在“控制面板”中,选择“网络和Internet”>“网络和共享中心”。在左侧窗格中,选择“更改适配器设置”。在“网络连接”窗口中,右键单击“本地连接”,然后选择“属性”。在“本地连接...
- 戴尔官网官方网站(戴尔产品官网)
-
查询步骤如下:1.在戴尔电脑的后盖上找到服务编号,并记录下来。2.之后搜索戴尔官网,在打开的官网界面中点击上方的支持选项,并点击产品支持。3.在打开的产品支持界面中,输入电脑后盖上的服务编号。4.如果...
- 黑鲨u盘重装系统教程(黑鲨u盘重装系统步骤8)
-
U盘重装WIn10系统:1、用【u深度u盘启动盘制作工具】制作u盘启动盘,插入电脑usb接口,设置好开机启动项进入u深度主菜单界面,选择“【02】u深度win8pe标准版(新机器)”并回车,2、在u深...
- 电子邮件免费注册入口(电子邮件在线注册)
-
1.在网页上搜索maiI163邮箱登录,如果有邮箱账号密码的话就直接输入并点击“登录”,没有的话就点击“立即注册”。2.点击“立即注册”后进入页面,输入信息点击“注册”。3.注册成功后就直接搜索登录。...
-
- win7如何快速启动(windows7如何快速启动)
-
打开操作系统运行:输入"cmd"并点击回车:系统命令提示符自动打开:使用方法直接运行start打开一个新的命令提示符窗口:运行start+文件的绝对存储路径打开对应的文件:运行start+文件夹路径打开对应...
-
2025-12-29 13:03 off999
- 怎么升级到win11(怎么升级到win11专业版)
-
Windows11可以在「开始菜单-设置-Windows更新」中进行手动更新。如果您想主动更新,需先确保您的电脑符合Windows11的最低系统要求。接着,打开「Windows更...
- 微信好友误删了怎么加回来(微信好友误删了怎么加回来免费)
-
看到他的评论的话,你可以去你发过的内容里去看看。<br/><br/>好友验证的消息、语音)或者朋友圈内容:<br/>如果你这个朋友喜欢和你在朋友圈聊天的话,你他的手机号也有的话方法添加里输入就可...
-
- access安装包(access安装包怎么安装)
-
要下载并安装MicrosoftAccess,可以按照以下步骤进行操作:1.打开您的电脑的浏览器(如谷歌浏览器、火狐浏览器等)。2.在浏览器的搜索栏中输入"下载MicrosoftAccess"。3.从搜索结果中选择适...
-
2025-12-29 11:51 off999
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
python入门到脱坑 输入与输出—str()函数
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
失业程序员复习python笔记——条件与循环
-
系统u盘安装(win11系统u盘安装)
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
