百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

构建并发布你的自定义 Python 包(创建自定义函数python)

off999 2025-07-02 23:51 30 浏览 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 twine


PyPI 上的包并不是以纯源代码的形式分发的。相反,它们被封装成分发包。最常见的分发包格式是源码归档和 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 的原因、过程和方法。


#我的宝藏兴趣#

相关推荐

windows查看ip命令(windows如何查看ip地址)

查看电脑IP:    1)使用Windows+R键打开“运行”窗口,然后输入CMD进入命令提示窗口2)进入命令窗口之后,输入:ipconfig/all回车即可...

内存条的作用(内存条的作用和参数配置)

内存条是存储电脑运行所需的数据和程序,帮助CPU快速读取和运行,提高计算机的运行速度和处理能力。内存条也被称为随机存取存储器(RAM),是电脑中非常必要的一个组件。常见的内存条类型有DDR、DDR2、...

autocad2012安装失败(autocad2012无法安装)

如果您遇到CAD2012安装不了的问题,可能有几个原因导致这种情况。以下是一些常见的解决方法:1.确保系统要求:首先,请确保您的计算机符合CAD2012的系统要求。检查您的操作系统版本、内存、处理器...

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”>“网络和共享中心”。在左侧窗格中,选择“更改适配器设置”。在“网络连接”窗口中,右键单击“本地连接”,然后选择“属性”。在“本地连接...

office2007官方免费版安装包
  • office2007官方免费版安装包
  • office2007官方免费版安装包
  • office2007官方免费版安装包
  • office2007官方免费版安装包
戴尔官网官方网站(戴尔产品官网)

查询步骤如下: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如何快速启动)
win7如何快速启动(windows7如何快速启动)

打开操作系统运行:输入"cmd"并点击回车:系统命令提示符自动打开:使用方法直接运行start打开一个新的命令提示符窗口:运行start+文件的绝对存储路径打开对应的文件:运行start+文件夹路径打开对应...

2025-12-29 13:03 off999

取消回复欢迎 发表评论: