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函数

交互模式测试导入模块.png

发布模块

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

1. 构建前的准备

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

构建前文件目录.png

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

安装setuptools和wheel.png

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

python setup.py sdist bdist_wheel

开始构建.png

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

构建后文件目录.png

上传模块到PyPI

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

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

安装上传工具twine.png

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

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

上传自己的模块.png

说明:

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下查看应该就能看到你上传的模块了。

test_pypi查看上传的模块.png

从PyPI安装自己的模块

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

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

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

从test_pypi安装自己的模块.png

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

验证已安装模块.png

最后的提示

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

python自己创建模块_创建并发布自己的python模块相关推荐

  1. grafana 创建仪表盘_创建仪表盘前要问的三个问题

    grafana 创建仪表盘 可视化 (VISUALIZATIONS) It's easier than ever to dive into dashboarding, but are you doin ...

  2. unity创建纹理_创建带纹理的文本的技术

    unity创建纹理 View demo 查看演示 Download Source 下载源 In this article we're going to explore several techniqu ...

  3. python的电脑推荐_推荐8款常用的Python GUI图形界面开发框架

    作为Python开发者,你迟早都会用到图形用户界面来开发应用.本文将推荐一些 Python GUI 框架,希望对你有所帮助,如果你有其他更好的选择,欢迎在评论区留言. Python 的 UI 开发工具 ...

  4. 经典python项目源码_建议收藏,22个Python迷你项目(附源码)

    在使用Python的过程中,我最喜欢的就是Python的各种第三方库,能够完成很多操作. 下面就给大家介绍22个通过Python构建的项目,以此来学习Python编程. 大家也可根据项目的目的及提示, ...

  5. python迷你停车管理系统_建议收藏,22个Python迷你项目(附源码)

    在使用Python的过程中,我最喜欢的就是Python的各种第三方库,能够完成很多操作. 下面就给大家介绍22个通过Python构建的项目,以此来学习Python编程. 大家也可根据项目的目的及提示, ...

  6. numpy是python标准库吗_吐血 整理!140种Python标准库、第三方库和外部工具都有了...

    Python数据工具箱涵盖从数据源到数据可视化的完整流程中涉及到的常用库.函数和外部工具.其中既有Python内置函数和标准库,又有第三方库和工具. 这些库可用于文件读写.网络抓取和解析.数据连接.数 ...

  7. python手势识别控制幻灯片_手把手教你如何实现Python手势识别与控制(含代码及动图)...

    Python手势识别与控制 概述 本文中的手势识别与控制功能主要采用 OpenCV 库实现, OpenCV是一个基于BSD许可(开源)发行的跨平台计算机视觉库, 可以运行在Linux, Windows ...

  8. python主要用于系统编程_一文带你了解python是什么?能做什么?为什么(附赠40G项目实战+绝版电子书)...

    什么是 Python? Python 是一门流行的编程语言.它由 Guido van Rossum 创建,于 1991 年发布. 它用于:当然小编这里也准备一份适合你的学习资料爬虫 ,python学习 ...

  9. 华为python面试题库_我收集了100道Python面试题,开源到了Github

    对于机器学习算法工程师而言,Python是不可或缺的语言,它的优美与简洁令人无法自拔.那么你了解过Python编程面试题吗?从Python基础到网页爬虫你是否能全方位Hold住?今天,机器之心为读者们 ...

最新文章

  1. getline简单例子
  2. wince下sources\sources.cmn\Makefile.def的相关作用
  3. Arthas 定位 Dubbo 手动注册 Eureka 异常
  4. python的scrapy框架的安装_Python爬虫基础(四)--Scrapy框架的安装及介绍
  5. php 页面开启错误提示,php开启与关闭错误提示
  6. Android RecyclerView封装下拉刷新与上拉加载更多
  7. Zabbix添加监控项及配置邮件报警
  8. 微型计算机是一种将CPU,Bwnhlq计算机一级考试选择题题库之微型计算机基础题及答案(XX年最新版)1.doc...
  9. OpenCV实现验证otsu算法
  10. 单元格自适应宽度_Excel – 合并单元格时,如何同时保留每个单元格的内容?...
  11. Garmin NUVI C255 固件刷机教程
  12. 2018年美赛E题M奖论文心得分享
  13. python第五章自己的笔记总结(6)
  14. 计算机考研408每日一题 day162
  15. 计算机审计风险背景,计算机审计风险探究
  16. 2020年中国激光切割运控系统需求现状及竞争格局分析,高功率快速增长「图」
  17. 经典算法-BF算法(字符串匹配)
  18. 操作系统和指弹吉他的联系
  19. rear和length表示的循环队列
  20. XTU OJ 1324 Hash

热门文章

  1. 聊聊网易技术如何帮教育行业开出花
  2. Android Studio 的 build 过程
  3. IBM推出云深度学习图形芯片Tesla P100 GPU加速器
  4. 《现代体系结构上的UNIX系统:内核程序员的对称多处理和缓存技术(修订版)》——2.11 高速缓存的性能...
  5. 推荐一个SAM文件中flag含义解释工具--转载
  6. Linux expect与Shell交互
  7. 第二次启用httpd24调用mysql时出现的错误
  8. SQL语句,统计一段时间内有多少个工作日
  9. 面试官问我JVM内存结构,我真的是
  10. 一篇文章教你学会Java基础JDBC