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

python包安装(python包安装命令)

off999 2024-10-24 12:24 37 浏览 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 文件做了以下几件事:

  1. 导入 setuptools 和 Extension。
  2. 定义一个 Extension 对象,指定模块名和源文件。这告诉 setuptools 如何编译 C 代码。
  3. 在 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],  # 包含扩展模块
)

相关推荐

大文件传不动?WinRAR/7-Zip 入门到高手,这 5 个技巧让你效率翻倍

“这200张照片怎么传给女儿?微信发不了,邮箱附件又超限……”62岁的张阿姨对着电脑犯愁时,儿子只用了3分钟就把照片压缩成一个文件,还教她:“以后用压缩软件,比打包行李还方便!”职场人更懂这...

电脑解压缩软件推荐——7-Zip:免费、高效、简洁的文件管理神器

在日常工作中,我们经常需要处理压缩文件。无论是下载软件包、接收文件,还是存储大量数据,压缩和解压缩文件都成为了我们日常操作的一部分。而说到压缩解压软件,7-Zip绝对是一个不可忽视的名字。今天,我就来...

设置了加密密码zip文件要如何打开?这几个方法可以试试~

Zip是一种常见的压缩格式文件,文件还可以设置密码保护。那设置了密码的Zip文件要如何打开呢?不清楚的小伙伴一起来看看吧。当我们知道密码想要打开带密码的Zip文件,我们需要用到适用于Zip格式的解压缩...

大文件想要传输成功,怎么把ZIP文件分卷压缩

不知道各位小伙伴有没有这样的烦恼,发送很大很大的压缩包会受到限制,为此,想要在压缩过程中将文件拆分为几个压缩包并且同时为所有压缩包设置加密应该如何设置?方法一:使用7-Zip免费且强大的文件管理工具7...

高效处理 RAR 分卷压缩包:合并解压操作全攻略

在文件传输和存储过程中,当遇到大文件时,我们常常会使用分卷压缩的方式将其拆分成多个较小的压缩包,方便存储和传输。RAR作为一种常见的压缩格式,分卷压缩包的使用频率也很高。但很多人在拿到RAR分卷...

2个方法教你如何删除ZIP压缩包密码

zip压缩包设置了加密密码,每次解压文件都需要输入密码才能够顺利解压出文件,当压缩包文件不再需要加密的时候,大家肯定想删除压缩包密码,或是忘记了压缩包密码,想要通过删除操作将压缩包密码删除,就能够顺利...

速转!漏洞预警丨压缩软件Winrar目录穿越漏洞

WinRAR是一款功能强大的压缩包管理器,它是档案工具RAR在Windows环境下的图形界面。该软件可用于备份数据,缩减电子邮件附件的大小,解压缩从Internet上下载的RAR、ZIP及其它类...

文件解压方法和工具分享_文件解压工具下载

压缩文件减少文件大小,降低文件失效的概率,总得来说好处很多。所以很多文件我们下载下来都是压缩软件,很多小伙伴不知道怎么解压,或者不知道什么工具更好,所以今天做了文件解压方法和工具的分享给大家。一、解压...

[python]《Python编程快速上手:让繁琐工作自动化》学习笔记3

1.组织文件笔记(第9章)(代码下载)1.1文件与文件路径通过importshutil调用shutil模块操作目录,shutil模块能够在Python程序中实现文件复制、移动、改名和删除;同时...

Python内置tarfile模块:读写 tar 归档文件详解

一、学习目标1.1学习目标掌握Python内置模块tarfile的核心功能,包括:理解tar归档文件的原理与常见压缩格式(gzip/bz2/lzma)掌握tar文件的读写操作(创建、解压、查看、过滤...

使用python展开tar包_python拓展

类Unix的系统,打包文件经常使用的就是tar包,结合zip工具,可以方便的打包并解压。在python的标准库里面有tarfile库,可以方便实现生成了展开tar包。使用这个库最大的好处,可能就在于不...

银狐钓鱼再升级:白文件脚本化实现GO语言后门持久驻留

近期,火绒威胁情报中心监测到一批相对更为活跃的“银狐”系列变种木马。火绒安全工程师第一时间获取样本并进行分析。分析发现,该样本通过阿里云存储桶下发恶意文件,采用AppDomainManager进行白利...

ZIP文件怎么打开?2个简单方法教你轻松搞定!

在日常工作和生活中,我们经常会遇到各种压缩文件,其中最常见的格式之一就是ZIP。ZIP文件通过压缩数据来减少文件大小,方便我们进行存储和传输。然而,对于初学者来说,如何打开ZIP文件可能会成为一个小小...

Ubuntu—解压多个zip压缩文件.zip .z01 .z02

方法将所有zip文件放在同一目录中:zip_file.z01,zip_file.z02,zip_file.z03,...,zip_file.zip。在Zip3.0版本及以上,使用下列命令:将所有zi...

如何使用7-Zip对文件进行加密压缩

7-Zip是一款开源的文件归档工具,支持多种压缩格式,并提供了对压缩文件进行加密的功能。使用7-Zip可以轻松创建和解压.7z、.zip等格式的压缩文件,并且可以通过设置密码来保护压缩包中的...

取消回复欢迎 发表评论: