Python实现在PyPI上发布自定义软件包的方法详解
作者:赵卓不凡 发布时间:2021-12-07 17:05:02
1. 引言
在Python中我们经常使用pip来安装第三方Python软件包,其实我们每个人都可以免费地将自己写的Python包发布到PyPI上,供他人来通过pip进行安装。
在本文中,我们将从一步一步地详细介绍如何发布测试包。
2. 创建PyPI账号
网址: https://pypi.org/
我们可以通过上面的链接在PyPI官网免费创建一个帐户。
我们需要先创建一个帐户,然后才能发布测试包。
3. 创建包名
我们可以发布任意我们想要定义的包名,只要和以前发布过的包没有重名过。我们可以快速在网站PyPI上检查是否有同名包。为了方便示例,我们使用aiway来作为示例的包名。
4. 按照如下格式组织包
需要注意的是我们可以使用任意我们想要发布的包名来替换上述aiway包名。
上述脚本 src/aiway/__init__.py内容如下:
def function():
print("hello from src/aiway/__init__.py")
脚本 src/aiway/test.py内容如下:
def testfunction():
print("hello from src/aiway/test.py")
脚本LICENSE: 我们这里留白
脚本README.md: 这里可以描述包的用途
脚本pyproject.toml,内容如下:
[build-system]
requires = ["setuptools>=42"]
build-backend = "setuptools.build_meta"
我们必须创建该文件
脚本 setup.py,内容如下:
from time import time
import setuptools
with open("README.md", "r", encoding="utf-8") as fh:
long_description = fh.read()
setuptools.setup(
name="aiway",
version="0.0.0",
author="Your Name Goes Here",
author_email="youremail@gmail.com",
description="A test package",
long_description=long_description,
long_description_content_type="text/markdown",
url="https://github.com/pypa/sampleproject",
project_urls={
"Bug Tracker": "https://github.com/pypa/sampleproject/issues",
},
classifiers=[
"Programming Language :: Python :: 3",
"License :: OSI Approved :: MIT License",
"Operating System :: OS Independent",
],
package_dir={"": "src"},
packages=setuptools.find_packages(where="src"),
python_requires=">=3.6",
)
5. 安装 Build & Twine
接着我们通过pip来安装我们的依赖包,命令如下:
pip install build twine
我们需要用到上述两个包来将我们的测试包推送到PyPI。安装过程如下:
6. 构建测试包
接着我们来编译我们的测试包,命令如下:
python -m build
在将包上载到PyPI之前,我们需要首先使用build构建它。上述命令的输出如下:
上述命令运行完成后,我们将会得到目录dist 以及 格式为 <package-name>.egg-info的包。如下所示:
7. 上传测试包
接着我们使用以下命令将包上传,如下所示:
python -m twine upload dist/*
包twine用来将我们的测试包上传至PyPI。上述命令执行过程中需要输入我们注册的网站的用户名和密码。如下所示:
同时我们可以在网站上看到我们上传的包,如下:
如果我们只是更新已经存在的包的版本,我们可以使用如下命令:
python -m twine upload dist/* --skip-existing
同时我们可以添加调试标志--verbose,来检查上述命令执行过程中的出错信息,如下:
python -m twine upload dist/* --skip-verbose
8. 总结
本文重点介绍了如何在PyPI上发布自定义软件包的流程,其中每一步都给出了详细的解释和图解。
来源:https://blog.csdn.net/sgzqc/article/details/125231169
猜你喜欢
- # -*- coding:utf-8 -*-# python3.3.3import sys,time,re,urllib.par
- 简介在php中,类型的继承使用extends关键字,而且最多只能继承一个父类,php不支持多继承。class MyClass {
- 问题描述尝试用Python写一个Wordcloud的时候,出现了编码问题。照着网上某些博客的说法添添改改后,结果是变成了“UnicodeDe
- vue配置文件vue.config.js配置前端代理将此代码片段命名为 vue.config.js,放在项目根目录即可仅需修改target属
- facade模式,即门面模式,也称外观模式,这个模式的核心思想是使用facade对象为外部客户端提供一个统一的访问一组子系统的接口,即客户端
- 今天是我们来玩一个钉子。通过一个钉子来学习一个opencv中的一个函数,这个函数我网上也有搜过,不过遗憾的是,各路好手都是写的是有点不堪入目
- 一、python的基础语法1.行连接的方法是最后加上一个‘\'2.注释:多行注释三引号,#行注释;三引号定义的字符串原样输出(保存原
- MySQL时间盲注五种延时方法 (PWNHUB 非预期解)延时注入函数五种:sleep(),benchmark(t,exp),笛卡尔积,GE
- ASP实现防止网站被采集代码如下:<% Dim AppealNum,AppealCount Appeal
- 合并numpy中numpy中可以通过concatenate,指定参数axis=0 或者 axis=1,在纵轴和横轴上合并两个数组。impor
- 这样虽没有对功能有什么影响,可是体验总不怎么好,那如何解决这个问题了,网上有很多文章都有说过在被目标页加载后设置window.status
- 一般事件事件浏览器支持描述onClickHTML: 2 | 3 | 3.2 |
- 第一种,也是我最常用的,第一帧里加上这个比较灵活,想要自定义加入菜单,只要定义drMenu这个对象就可以了var drMenu&n
- 前言在db中存储json格式的数据,相信大家都或多或少的使用过,那么在查询这个json结构中的数据时,有什么好的方法么?取出String之后
- 在之前的Python办公自动化案专题中,我们已经介绍了如何有选择的提取某些页面进行合并。但是很多时候,我们并不会预知希望提取的页号,而是希望
- Python:2.7 IDE:Pycharm5.0.3 今天遇到一个问题,就是在使用json.load()时,中文字符被转化为Unicode
- 有很多程序运行时间比较长,如果不将运行过程输出将很难判断程序运行的时间。下边这段程序将按照上图所示的格式输出程序运行进程、已用时间、剩余时间
- 手痒痒系列之简单的放大镜写了个放大镜功能,可以设置显示的宽高width,height显示的位置,float ‘left’ 'righ
- 打包下载Pain.php <?php class Pain { public $var=array(); public $tpl=ar
- date("yyyyMMdd",time()) date() 函数功能:用于格式化时间,返回一个字符串。&nb