python包安装(python包安装命令)
off999 2024-10-24 12:24 42 浏览 0 评论
安装过程
如果有一个 Python 包,可以使用以下命令在包的根目录(其中包含 setup.py 文件)生成 wheel 文件:
python setup.py bdist_wheel这个命令会在 dist/ 目录下创建一个 .whl 文件。这个 wheel 文件可以被分发和安装到其他系统上,而不需要源代码或者重新编译任何东西。
以下命令来安装这个 wheel 文件:
pip install /path/to/dist/bdist_wheel.whl如下是这个过程的详细描述,pip install 从远程下载并安装包的过程与从本地安装 .whl 文件的过程非常相似。
1.解析 Wheel 文件
首先,pip 需要解析 wheel 文件的名称。Wheel 文件名遵循一个标准的命名约定,包含包名、版本号、构建标签、Python 标签、ABI 标签和平台标签。这些信息帮助 pip 确定该文件是否与当前的 Python 环境兼容。
2.检查兼容性
pip 根据 wheel 文件名中的 Python 版本、ABI(应用程序二进制接口)和平台标签检查 wheel 是否适用于当前环境。如果不兼容,pip 会报错并停止安装。
3.提取和安装包
如果 wheel 文件与环境兼容,pip 会将 .whl 文件解压到一个临时目录。这个解压包含了预编译的扩展模块(如果有的话)、Python 模块和包、以及相关的元数据。
接下来,pip 会将这些文件复制到正确的位置,通常是 Python 的 site-packages 目录。这样,安装的包就可以在 Python 环境中被导入和使用了。
4.处理依赖
Wheel 文件包含了一个名为 METADATA 的文件,其中包含了包的依赖信息。pip 会解析这些依赖,并递归地安装所需的任何其他包。这一步骤确保了包及其所有依赖都被安装,使得包可以正常工作。
5.编译扩展(如果需要)
虽然 wheel 文件通常包含预编译的扩展,但在某些情况下(如纯 Python wheel),如果包含需要在目标系统上编译的扩展,则 pip 会处理这些编译过程。这种情况比较少见,因为 wheel 的主要优势之一就是避免了编译步骤。
6.更新元数据和记录
安装完成后,pip 会更新相关的元数据和安装记录,这包括安装包的名称、版本和位置等信息。这些信息用于未来的包管理操作,如升级、卸载等。
setup.py示例一
from setuptools import find_packages, setup
from setuptools.command.install import install
class DownloadNLTK(install):
def run(self):
self.do_egg_install()
import nltk
nltk.download('punkt')
def readme():
with open('README.md', encoding='utf-8') as f:
content = f.read()
return content
def parse_requirements(fname='requirements.txt', with_version=True):
import re
import sys
from os.path import exists
require_fpath = fname
def parse_line(line):
"""Parse information from a line in a requirements text file."""
if line.startswith('-r '):
# Allow specifying requirements in other files
target = line.split(' ')[1]
for info in parse_require_file(target):
yield info
else:
info = {'line': line}
if line.startswith('-e '):
info['package'] = line.split('#egg=')[1]
else:
# Remove versioning from the package
pat = '(' + '|'.join(['>=', '==', '>']) + ')'
parts = re.split(pat, line, maxsplit=1)
parts = [p.strip() for p in parts]
info['package'] = parts[0]
if len(parts) > 1:
op, rest = parts[1:]
if ';' in rest:
# Handle platform specific dependencies
# http://setuptools.readthedocs.io/en/latest/setuptools.html#declaring-platform-specific-dependencies
version, platform_deps = map(str.strip,
rest.split(';'))
info['platform_deps'] = platform_deps
else:
version = rest # NOQA
if '--' in version:
# the `extras_require` doesn't accept options.
version = version.split('--')[0].strip()
info['version'] = (op, version)
yield info
def parse_require_file(fpath):
with open(fpath, 'r') as f:
for line in f.readlines():
line = line.strip()
if line and not line.startswith('#'):
for info in parse_line(line):
yield info
def gen_packages_items():
if exists(require_fpath):
for info in parse_require_file(require_fpath):
parts = [info['package']]
if with_version and 'version' in info:
parts.extend(info['version'])
if not sys.version.startswith('3.4'):
# apparently package_deps are broken in 3.4
platform_deps = info.get('platform_deps')
if platform_deps is not None:
parts.append(';' + platform_deps)
item = ''.join(parts)
yield item
packages = list(gen_packages_items())
return packages
def get_version():
version_file = 'opencompass/__init__.py'
with open(version_file, 'r', encoding='utf-8') as f:
exec(compile(f.read(), version_file, 'exec'))
return locals()['__version__']
def do_setup():
setup(name='opencompass',
author='OpenCompass Contributors',
version=get_version(),
description='A comprehensive toolkit for large model evaluation',
url='https://github.com/open-compass/opencompass',
long_description=readme(),
long_description_content_type='text/markdown',
maintainer='OpenCompass Authors',
cmdclass={'download_nltk': DownloadNLTK},
setup_requires=['nltk==3.8'],
python_requires='>=3.8.0',
install_requires=parse_requirements('requirements/runtime.txt'),
license='Apache License 2.0',
packages=find_packages(exclude=[
'test*',
'configs',
'data',
'docs',
'tools',
'tmp',
]),
keywords=[
'AI', 'NLP', 'in-context learning', 'large language model',
'evaluation', 'benchmark', 'llm'
],
classifiers=[
'Programming Language :: Python :: 3.8',
'Programming Language :: Python :: 3.9',
'Programming Language :: Python :: 3.10',
'Intended Audience :: Developers',
'Intended Audience :: Education',
'Intended Audience :: Science/Research',
])
if __name__ == '__main__':
do_setup()这段代码是https://github.com/open-compass/opencompass的 setup.py 脚本,用于定义包的安装和分发配置。
1.导入模块和定义自定义安装命令
DownloadNLTK 类继承自 setuptools.command.install.install,用于扩展标准的安装过程。在安装包时,这个自定义命令会下载 NLTK 的 punkt 数据集。
2.定义读取 README 文件的函数
这个函数读取包的 README 文件,通常用于在 PyPI 上显示长描述。
3.解析依赖关系
函数解析 requirements.txt 文件(或其他指定的依赖文件),提取包依赖。它支持读取其他文件中的依赖(通过 -r 指令)、处理 -e (可编辑安装)依赖,并且可以选择是否包含版本信息。
4.获取包版本
函数从 opencompass/__init__.py 文件中读取包的版本号。这是一个常见的模式,包的版本号通常在包的 __init__.py 文件中定义为 __version__。
5.定义 setup() 函数
do_setup() 函数调用 setup(),这是 setuptools 库的核心功能,用于配置包的安装和分发。它包含很多参数,定义了如何打包和安装这个 Python 包:
- name、author、version 等字段定义了包的基本信息。
- long_description 通常用 README 文件的内容填充,这样在 PyPI 上会显示更详细的包描述。
- cmdclass 允许你指定自定义的命令类,这里用来在安装时运行 DownloadNLTK 类。
- setup_requires 定义了运行 setup 脚本本身所需的依赖。
- install_requires 定义了包运行时的依赖,这里通过 parse_requirements() 函数获取。
- packages 指定了要包含在分发中的包目录,find_packages() 函数用于自动查找这些目录。
- classifiers 提供了一些元数据,如包的目标编程语言版本和目标受众。
6.执行安装脚本
最后,如果直接执行这个脚本(而不是被其他脚本导入),它会调用 do_setup() 函数来执行安装过程。这允许通过命令行直接安装包,也允许该脚本作为模块被其他 Python 脚本导入和使用。
setup.py示例二
如下包含二进制扩展setup.py 文件做了以下几件事:
- 导入 setuptools 和 Extension。
- 定义一个 Extension 对象,指定模块名和源文件。这告诉 setuptools 如何编译 C 代码。
- 在 setup 函数中定义包的元数据,并将扩展模块列表传递给 ext_modules 参数。
当运行 python setup.py build_ext 时,setuptools 会编译 hello.c 并生成一个可从 Python 导入的共享库。运行 python setup.py install,这个扩展模块会与其他 Python 模块一起安装到 Python 环境中。
from setuptools import setup, Extension, find_packages
# 定义一个扩展模块
hello_extension = Extension(
'my_package.hello', # 模块的完整名称
sources=['src/hello.c'], # 源文件的路径
)
# 使用 setup 函数定义包
setup(
name='my_package',
version='0.1.0',
author='Your Name',
author_email='your.email@example.com',
description='An example package with a binary extension',
long_description='This is a long description for the package.',
packages=find_packages(),
ext_modules=[hello_extension], # 包含扩展模块
)
相关推荐
- win10iso文件(win10iso文件怎么安装)
-
安装Win10ISO系统文件需要以下步骤:1.首先需要从Microsoft官网下载Win10ISO系统文件,打开网站后选择Win10的版本、语言和架构(32位或64位),点击下载即可。2.下载...
- 英特尔显卡性能排行(英特尔显卡性能排行天梯图)
-
IRIS(英特尔第四/五代集成显卡)英特尔第四代集成显卡,分为HD4200/4400/4600,HD5100/5200。代号为GT2/3/3e,中文名为锐炬。hd420044004600和台式...
- 电脑做系统u盘启动选项(做系统开机u盘怎么选择)
-
操作须知:1、设置U盘启动分很多种:传统legacy机型设置、uefi新机型设置、uefi机型改legacy启动设置2、由于电脑品牌以及机型非常多,这边仅列举一部分电脑的设置方法,3、如果是uefi机...
- 未安装nvidia控制面板(电脑未安装nvidia控制面板)
-
如果你使用的是Nvidia显卡,但未安装Nvidia控制面板,则可能会遇到以下问题:1.无法进行高级显卡设置:Nvidia控制面板提供了高级显卡设置选项,例如显卡超频、显示器分辨率和刷新率、视频调整...
- u盘检测不到怎么修复(u盘检查不了是什么原因)
-
以下是可能的解决办法:1.更换不同的USB端口。有时候电脑某个USB端口可能出现问题,试试换一个不同的端口。2.重启电脑。有时候出现问题的USB端口可能需要重启才能正常。3.插拔几次U盘。有时候...
- win7 共享设置(win7共享设置详细步骤)
-
1.进入控制面板家庭组页打开控制面板找到网络和Internet下面的家庭组和共享选项并打开?2.进入更改高级共享设置打开以后选择更改高级共享设置功能进入?3.开启文件和打印机共享开启文件和打印机共享,...
- 电脑硬盘怎么装步骤图(电脑硬盘怎么装步骤图片)
-
1、查看硬盘的各项信息。硬盘的背面会有硬盘的存储容量以及电压,功率,转速等基本信息。2、购买到的一整块硬盘里面包括硬盘、对接线跟螺丝钉。将对接线和螺丝钉摆在一旁。3、在硬盘的上方会有两个SATA接口,...
- 小马win10永久激活(小马win10永久激活工具使用方法)
-
很简单,重装系统win7,这个可以激活的,然后根据推送升级win10,如果有强迫症可以升级以后重新安装win10系统,以后都是自动联网激活的。安全。小马激活工具win10版是小马专门为windowns...
- win10开机欢迎时间太长(开机欢迎界面时间长)
-
win10第一个就是你系统里的垃圾太多,如果系统垃圾太多,直接清理垃圾就可以解决这个问题,第二个就是你的开机启动项过多,如果开机启动项过多,直接关闭不必要的开机启动项就可以缩短开机时间,就可以解决你...
- 登录126邮箱入口(登录126邮箱入口官网)
-
126邮箱是网易的一个免费邮箱登录入口在浏览器输入:mail.126.com浏览器进入126邮箱网站之后,即可自行登录126邮箱账号。如何在手机上登录126邮箱1、打开手机,找到并打开网易邮箱软件。2...
- 如何让防火墙允许某个软件(如何允许防火墙阻止访问)
-
1.打开电脑的开始菜单,找到控制面板选项,并点击打开。2.在打开的控制面板中,找到防火墙选项,并点击打开。3.在打开的防火墙界面中,单击左侧的允许程序通过防火墙选项。4.在跳转的界面中,选择允许通过防...
-
- 智慧工厂管理系统(智慧工厂管理系统哪家好)
-
智慧工厂智能化系统整体的解决方案分为三个主要部分,分别是现场控制系统(FDC)、生产数据管理系统(PDM)以及工厂数字化协同平台(LCT)。其中,现场控制系统(FDC)是智慧工厂系统非常重要的核心组成部分,它是一个支持大规模互联的集群控制系...
-
2025-11-13 22:03 off999
- 电脑如何打开隐藏文件(电脑怎么打开隐藏文件夹)
-
要显示隐藏文件,首先需要打开文件资源管理器,然后点击菜单栏中的“查看”选项,选中“隐藏项目”复选框即可。此时,隐藏文件和文件夹将会显示在文件资源管理器中,可以进行正常操作。如果需要隐藏文件和文件夹,可...
欢迎 你 发表评论:
- 一周热门
-
-
抖音上好看的小姐姐,Python给你都下载了
-
全网最简单易懂!495页Python漫画教程,高清PDF版免费下载
-
Python 3.14 的 UUIDv6/v7/v8 上新,别再用 uuid4 () 啦!
-
python入门到脱坑 输入与输出—str()函数
-
飞牛NAS部署TVGate Docker项目,实现内网一键转发、代理、jx
-
宝塔面板如何添加免费waf防火墙?(宝塔面板开启https)
-
Python三目运算基础与进阶_python三目运算符判断三个变量
-
(新版)Python 分布式爬虫与 JS 逆向进阶实战吾爱分享
-
慕ke 前端工程师2024「完整」
-
失业程序员复习python笔记——条件与循环
-
- 最近发表
- 标签列表
-
- python计时 (73)
- python安装路径 (56)
- python类型转换 (93)
- python进度条 (67)
- python吧 (67)
- python的for循环 (65)
- python格式化字符串 (61)
- python静态方法 (57)
- python列表切片 (59)
- python面向对象编程 (60)
- python 代码加密 (65)
- python串口编程 (77)
- python封装 (57)
- python写入txt (66)
- python读取文件夹下所有文件 (59)
- python操作mysql数据库 (66)
- python获取列表的长度 (64)
- python接口 (63)
- python调用函数 (57)
- python多态 (60)
- python匿名函数 (59)
- python打印九九乘法表 (65)
- python赋值 (62)
- python异常 (69)
- python元祖 (57)
