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

创建并发布自己的python模块_创建一个python项目

itomcoil 2025-02-20 15:55 14 浏览

python通过模块来共享组织代码,python不仅内置了丰富的标准库,而且python社区还贡献了大量的第三方模块,正是由于第三方模块大大扩展了python的应用领域,成就了如今python的江湖地位。人人都可以向社区共享代码,PyPI(Python Package Index)为第三方python模块提供了一个集中的存储库,今天我们就来尝试建立自己的模块并发布到PyPI上。

以下内容在windows10系统下验证OK,其他系统应该差别不大,linux系统python3版本需要将python命令替换为python3

创建模块

所谓模块就是一个包含python代码的文本文件,扩展名为.py。我们以一个简单的打印嵌套列表的函数为例,在某个目录下新建一个.py扩展名的文件(如nestList.py),输入如下代码:

#python 3.7
"""
模块示例
可以打印嵌套列表
"""

# indent表示缩进,默认0表示无缩进
def print_list(lst, indent = 0):
    for item in lst:
        # 判断列表lst中的每一项是否是list对象,
        # 如果是则递归调用print_list,同时缩进级别加1
        if isinstance(item, list):   
            print_list(item, indent + 1)
        else:
            print("--" * indent, end="")
            print(item)

打开终端,cd到该.py文件所在的目录,执行python命令进入交互模式,通过import直接导入该模块测试print_list函数

发布模块

上一节我们已经创建并测试了我们的模块,但是如果我们要共享模块,还需要一些额外的文件,这些文件集合在一起允许你构建、打包和发布你自己的模块

1. 构建前的准备

构建模块前我们需要创建类似如下的文件目录结构,example_pkg目录下创建文件LICENSE,README.md,setup.py三个文件,子目录example_pkg_zx1下创建__init__.py(注意是两个下划线),拷贝上一节创建的nestList.py到此目录下,我们逐个说明下其余各个文件的内容。

  • setup.py是setuptools的构建脚本,它告诉setuptools你的包的相关信息(如包名称、版本等)
import setuptools

with open("README.md", "r", encoding="utf-8") as fh:
    long_description = fh.read()

setuptools.setup(
    name="example_pkg_zx1",
    version="0.0.1",
    author="Example Author",
    author_email="author@example.com",
    description="A small example package",
    long_description=long_description,
    long_description_content_type="text/markdown",
    url="https://github.com/PepperPapa/xinNotes",
    packages=setuptools.find_packages(),
    classifiers=[
        "Programming Language :: Python :: 3",
        "License :: OSI Approved :: MIT License",
        "Operating System :: OS Independent",
    ],
)

name,version,author,author_email,description,url根据名称的含义参考你的模块功能进行填写即可,没有特别要注意的地方。(注:name参数在上传到internet上要求必须是唯一的,不能有重复,否则无法上传)long_description为读取README.md的内容,encoding="utf-8"设置是为了README.md的内容支持中文,
long_description_content_type执定long_description内容格式为markdown。packages通过setuptools.find_packages()函数会查找目录example_pkg_zx1下所有需要包含的模块,避免手工输入的麻烦。classifiers提供一些额外的模块信息,是一个列表格式。

  • LICENSE是规定了你使用哪种协议发布自己的模块,如下MIT license的内容。如果你只是学习如何发布,直接copy如下内容即可,不用特别关注。
Copyright (c) 2018 The Python Packaging Authority

Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all
copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
SOFTWARE.
  • README.md的内容也就是对模块的详细说明,示例如下:
# Example Package

nestList.py是一个可以打印缩进列表的示例函数,示例代码如下:

    from example_pkg_zx1 import nestList
    alist = ["grace", "angle", "roy", 
                ["anna", "jhon", "richard", ["nio", "lily"]], 
                "bluce"]        
    nestList.print_list(alist)
  • __init__.py仅一行代码,提供模块名称信息
name = "example_pkg_zx1"

2. 构建发布文件

接下来就是要构建发布文件了,会用到setuptools和wheel两个工具,终端下执行如下命令确保已经安装了最新版本

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

接着在setup.pyt文件所在目录下执行如下命令开始构建

python setup.py sdist bdist_wheel

构建完成后会创建多个文件及目录,其中dist目录下会生成.whl和.tar.gz两个文件

上传模块到PyPI

最激动人心的莫过是把自己的模块分享到internet上,让全球的程序员都能使用你贡献的代码,想想都很激动吧。因为只是演示如何上传模块,并不是真正有用的模块,最好是能通过一个测试平台来给大家来练习,Test PyPI就是提供这样的功能,让你随意上传自己的模块进行测试和实验,首先你需要在注册Test PypI页面上注册一个账户并登陆邮箱验证。上传发布包需要用到twine这个工具,首先需要通过下面的命令进行安装。

python -m pip install --user --upgrade twine

安装成功后,在example_pkg目录下使用下面的命令上传你的发布包

twine upload --repository-url https://test.pypi.org/legacy/ dist/*

说明:
1.你的模块名称及子目录名称(示例为example_pkg_zx1)不能有重复,否则上传会失败,提示HTTPError: 403 Client Error: The user 'xxxx' isn't allowed to upload to project 'example-pkg'错误,遇到这种情况需要修改子目录example_pkg_zx1及setup.py中的name,然后重新尝试上传直到成功。

提示上传成功后,登陆Test PypI页面Your projects下查看应该就能看到你上传的模块了。

从PyPI安装自己的模块

你可以使用pip从Test PyPI上安装你的模块来验证是否能工作,example_pkg_zx1为模块名称

python -m pip install --index-url https://test.pypi.org/simple/ example_pkg_zx1

注意上面的命令不要在example_pkg目录下执行,否则会提示模块已经存在而不执行安装,随意cd到其他的目录下执行


交互模式下测试已安装的模块

最后的提示

如果你已经准备好了正式发布自己的模块到PyPI(与Test PyPI不同哦),你需要首先在https://pypi.org上注册正式的账户并验证邮箱,twine上传命令直接使用"twine upload dist/*"命令即可,不用再指定url;同样从PyPI安装模块直接使用命令"pip install your-package-name"进行安装,也不用指定url。

相关推荐

最强聚类模型,层次聚类 !!_层次聚类的优缺点

哈喽,我是小白~咱们今天聊聊层次聚类,这种聚类方法在后面的使用,也是非常频繁的~首先,聚类很好理解,聚类(Clustering)就是把一堆“东西”自动分组。这些“东西”可以是人、...

python决策树用于分类和回归问题实际应用案例

决策树(DecisionTrees)通过树状结构进行决策,在每个节点上根据特征进行分支。用于分类和回归问题。实际应用案例:预测一个顾客是否会流失。决策树是一种基于树状结构的机器学习算法,用于解决分类...

Python教程(四十五):推荐系统-个性化推荐算法

今日目标o理解推荐系统的基本概念和类型o掌握协同过滤算法(用户和物品)o学会基于内容的推荐方法o了解矩阵分解和深度学习推荐o掌握推荐系统评估和优化技术推荐系统概述推荐系统是信息过滤系统,用于...

简单学Python——NumPy库7——排序和去重

NumPy数组排序主要用sort方法,sort方法只能将数值按升充排列(可以用[::-1]的切片方式实现降序排序),并且不改变原数组。例如:importnumpyasnpa=np.array(...

PyTorch实战:TorchVision目标检测模型微调完

PyTorch实战:TorchVision目标检测模型微调完整教程一、什么是微调(Finetuning)?微调(Finetuning)是指在已经预训练好的模型基础上,使用自己的数据对模型进行进一步训练...

C4.5算法解释_简述c4.5算法的基本思想

C4.5算法是ID3算法的改进版,它在特征选择上采用了信息增益比来解决ID3算法对取值较多的特征有偏好的问题。C4.5算法也是一种用于决策树构建的算法,它同样基于信息熵的概念。C4.5算法的步骤如下:...

Python中的数据聚类及可视化分析实践

探索如何通过聚类分析揭露糖尿病预测数据集的特征!我们将运用Python的强力工具,深入挖掘数据,以直观的可视化揭示不同特征间的关系。一同探索聚类分析在糖尿病预测中的实践!所有这些可视化都可以通过数据操...

用Python来统计大乐透号码的概率分布

用Python来统计大乐透号码的概率分布,可以按照以下步骤进行:导入所需的库:使用Python中的numpy库生成数字序列,使用matplotlib库生成概率分布图。读取大乐透历史数据:从网络上找到大...

python:支持向量机监督学习算法用于二分类和多分类问题示例

监督学习-支持向量机(SVM)支持向量机(SupportVectorMachine,简称SVM)是一种常用的监督学习算法,用于解决分类和回归问题。SVM的目标是找到一个最优的超平面,将不同类别的...

25个例子学会Pandas Groupby 操作

groupby是Pandas在数据分析中最常用的函数之一。它用于根据给定列中的不同值对数据点(即行)进行分组,分组后的数据可以计算生成组的聚合值。如果我们有一个包含汽车品牌和价格信息的数据集,那么可以...

数据挖掘流程_数据挖掘流程主要有哪些步骤

数据挖掘流程1.了解需求,确认目标说一下几点思考方法:做什么?目的是什么?目标是什么?为什么要做?有什么价值和意义?如何去做?完整解决方案是什么?2.获取数据pandas读取数据pd.read.c...

使用Python寻找图像最常见的颜色_python 以图找图

如果我们知道图像或对象最常见的是哪种颜色,那么可以解决图像处理中的几个用例,例如在农业领域,我们可能需要确定水果的成熟度。我们可以简单地检查一下水果的颜色是否在预定的范围内,看看它是成熟的,腐烂的,还...

财务预算分析全网最佳实践:从每月分析到每天分析

原文链接如下:「链接」掌握本文的方法,你就掌握了企业预算精细化分析的能力,全网首发。数据模拟稍微有点问题,不要在意数据细节,先看下最终效果。在编制财务预算或业务预算的过程中,通常预算的所有数据都是按月...

常用数据工具去重方法_数据去重公式

在数据处理中,去除重复数据是确保数据质量和分析准确性的关键步骤。特别是在处理多列数据时,保留唯一值组合能够有效清理数据集,避免冗余信息对分析结果的干扰。不同的工具和编程语言提供了多种方法来实现多列去重...

Python教程(四十):PyTorch深度学习-动态计算图

今日目标o理解PyTorch的基本概念和动态计算图o掌握PyTorch张量操作和自动求导o学会构建神经网络模型o了解PyTorch的高级特性o掌握模型训练和部署PyTorch概述PyTorc...