python whl文件_python之PypI打包whl文件

一.简单介绍

python中我们经常会用到第三方的包作为工具,比如爬虫解析工具,网络请求工具等。之所以要把它封装成包,意识为了技术与业务分离,二是为了能多

项目多平台共用。python里面用到的第三方工具包基本都是从Pypi.org里面下载的。下面具体介绍如何打一个自己的包上传到Pypi中作为工具使用。

二.Pypi打包whl文件

首先,我们需要确认我们需要打包的package中已经包含了README.md、LICENSE[非必须]和setup/py文件。三者分别是说明文档,许可证以及

python setuptools所用来安装该package的构建脚本。

2.1 setup.py

setup.py中包含了package对应的信息(例如该package的名称、版本、作者)以及该package应当包含的程序文件和数据。

下面是一个setup.py的示例文件:

import os

from setuptools import setup, find_packages

path = os.path.abspath(os.path.dirname(__file__))

try:

with open(os.path.join(path, 'README.md')) as f:

long_description = f.read()

except Exception as e:

long_description = "customize okta cli"

setup(

name = "okta-cmd",

version = "0.1.0",

keywords = ("pip", "okta", "cli", "cmd", "steven"),

description = "okta cli",

long_description = long_description,

long_description_content_type='text/markdown',

python_requires=">=3.5.0",

license = "MIT Licence",

url = "https://github.com/stevenQiang/okta-cmd",

author = "steven",

author_email = "qianggao7@gmail.com",

packages = find_packages(),

include_package_data = True,

install_requires = ["requests", "click"],

platforms = "any",

scripts = [],

entry_points = {

'console_scripts': [

'okta-cmd=oktacmd:main_cli'

]

}

)

name: 该package的名字,该名字可以由字母、数字、-组成,注意这个名字不能与其它已经上传到pypi.org的项目相同

version: 这个就是包的发布版本,可以直接写在这,也可以从其它地方引用

author: author可以用来指定该package的作者信息

author_email: 这个也是指定该package的作者信息

description: 对当前package的较短的总结

long_description: 是对当前package的详细说明。这一详细说明将被展示在Python Package Index上当前项目的主页

long_description_content_type: 指定了long_description内容的格式。在当前情况下为markdown

url: 是当前package的主页链接。大多数情况下这是一个GitHub, GitLab, Bitbucket或者其他代码存储服务的链接

packages: 是一系列应当包含在发布软件包文件(distribution package)中的可被import的python包文件。我们可以手动在此处罗列所有文件。

或者如本例中一样使用find_packages()函数自动包含所有的python包文件以及子包文件。

python_requires: python依懒版本

classifiers: 指定了当前package的其他元信息(metadata)。例如当前package兼容的python版本和操作系统,当前package提供的功能的类型,

当前package的许可证等等。我们应当总是至少包括当前package所支持的python版本,操作系统和许可证。注意此处定义的classifiers关键字

所包含的信息应当符合PyPI的规定。

install_requires: 指定了当前package所依赖的其他python类库。这些指定的python类库将会在本package被安装的时候一并被安装。

platforms: 程序适用的软件平台列表

keywords: 程序的关键字列表

include_package_data: 是否自动包含包内所有受版本控制(cvs/svn/git)的数据文件,默认True

entry_points: 用来支持自动生成cli命令

使用上面的配置信息之后,会生成一个okta-cmd的命令,可以直接使用,就是在entry_points里面配置的。

目录结构:

├── LICENSE

├── README.md

├── oktacmd

│ ├── __init__.py

│ ├── cli.py

│ ├── common.py

│ ├── main.py

│ └── okta.py

├── setup.py

└── setup.sh

生成包:

1.安装最新版的setuptools和wheel

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

2.使用sdist构建源码分发包

python setup.py sdist bdist_wheel

注意: 这里是固定的命令(确保setup.py存在于当前路径下)

当这个命令运行结束后,确保在生成的dist/文件夹下存在相应的.whl文件和.tar.gz文件。其中.tar.gz文件是我们的python package的源文件文档,

而.whl是一个软件分发包(build distribution)。新版本的pip将会首先尝试安装软件分发包,但在失败情况下会接着尝试采用源文件包安装。

三.上传项目至PyPI

首先注册一个PyPI的账号,链接https://pypi.org/

安装最新版本twine

python3 -m pip install --user --upgrade twine

3.上传项目

使用twine上传项目的时候需要输入相应的PyPI的账号和密码。

python3 -m twine upload dist/*

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值