zoukankan      html  css  js  c++  java
  • python包管理(distutils、easy_install、pip、setup.py/requirements.txt、wheel)

    distutils、distutils2

    distutils是 python 标准库的一部分,2000年发布。使用它能够进行 python 模块的 安装发布

    distutils2 被设计为 distutils 的替代品,后来这个计划停滞了。

    setuptools、easy_install、ez_setup.py

    setuptools 是一个为了增强 distutils 而开发的集合,2004年发布。它包含了 easy_install 这个工具。

    ez_setup.py 是 setuptools 的安装工具。ez 是 easy 的缩写。

    使用方式:

    • 从 PyPI 上安装一个包:easy_install requests
    • 从网络文件安装(下载并安装):easy_install http://path/to/MyPackage-1.2.3.tgz
    • 从一个本地 .egg 格式文件安装:easy_install /path/to/MyPackage-1.2.3.egg

    distribute 是 setuptools 的一个分支版本,后来又合并到了setuptools。

    pip

    pip 是目前 python 包管理的事实标准,2008年发布。它被用作 easy_install 的替代品,但是它仍有大量的功能建立在 setuptools 组件之上。

    pip 希望不再使用 Eggs 格式(虽然它支持 Eggs),而更希望采用“源码发行版”(使用 python setup.py sdist 创建)。

    pip使用方式:

    • pip 可以利用 requirments.txt 来实现依赖的安装。
    • 支持 git/svn/hg 等流行的 VCS 系统,可以直接从 gz 或者 zip 压缩包安装,支持搜索包,以及指定服务器安装等等功能。
    • pip 提供了一个 wheel 子命令来安装 wheel 包。需要先安装 wheel 模块。

    setup.py vs requirements.txt

    • Python库:那些被开发并且为了其他人来使用而发布的东西,你可以在 PyPI 找到很多Python库。为了更好的推广和传播 自己,Python库会包含很多的信息,比如它的名字,版本号,依赖等等。而 setup.py 就是用来提供这些信息的。但是,并没有规定你可以从哪里获取这些依赖库。
    • Python应用:指你所要部署的一些东西,这是区别于我们之前所讲的Python库的。一个应用经常会有很多依赖,或许会很复杂。这些依赖里很多没有一个名字,或者没有我们说所的那些信息。这便反映了 pip 的requirements文件所做的事情了。每个依赖都标明了准确的版本号,一般一个Python库对依赖的版本比较宽松,而一个应用則会依赖比较具体的版本号。虽然也许跑其他 版本的 requests 并不会出错,但是我们在本地测试顺利后,我们就会希望在线上也跑相同的版本。执行pip install -r requirements.txt来安装。

    setup.py

    from setuptools import setup
    
    setup(
        name="MyLibrary",
        version="1.0",
        install_requires=[
            "requests",
            "bcrypt",
        ],
        # ...
    )
    

    requirements.txt

    # This is an implicit value, here for clarity
    --index https://pypi.python.org/simple/
    
    MyPackage==1.0
    requests==1.2.0
    bcrypt==1.0.2
    

    从抽象到具体

    上面这个requirements.txt文件的头部有一个 --index https://pypi.python.org/simple/ ,一般如果你不用声明这项,除非你使用的不是PyPI。然而它却是 requirements.txt 的一个重要部分, 这一行把一个抽象的依赖声明 requests==1.2.0 转变为一个具体的依赖声明 requests 1.2.0 from pypi.python.org/simple/

    setup.py 中,也存在一个 install_requires 表来指定依赖的安装。这一功能除去了依赖的抽象特性,直接把依赖的获取url标在了setup.py里。Link

    from setuptools import setup
    
    setup(
        # ...
        dependency_links = [
            "http://packages.example.com/snapshots/",
            "http://example2.com/p/bar-1.0.tar.gz",
        ],
    )
    

    wheel

    wheel 本质上是一个 zip 包格式,它使用 .whl 扩展名,用于 python 模块的安装,它的出现是为了替代 Eggs。

    wheel 还提供了一个 bdist_wheel 作为 setuptools 的扩展命令,这个命令可以用来生成 wheel 包。

    pip 提供了一个 wheel 子命令来安装 wheel 包。

    setup.cfg 可以用来定义 wheel 打包时候的相关信息。

    Python Wheels 网站展示了使用 Wheels 发行的 python 模块在 PyPI 上的占有率。

    .whl文件下载:http://www.lfd.uci.edu/~gohlke/pythonlibs/

    总结

    安装

    • Use pip to install Python packages from PyPI. Depending how pip is installed, you may need to also install wheel to get the benefit of wheel caching.
    • Use virtualenv, or pyvenv to isolate application specific dependencies from a shared Python installation.
    • If you’re looking for management of fully integrated cross-platform software stacks, consider buildout (primarily focused on the web development community) or Hashdist, or conda (both primarily focused on the scientific community).

    打包

    • Use setuptools to define projects and create Source Distributions.
    • Use the bdist_wheel setuptools extension available from the wheel project to create wheels. This is especially beneficial, if your project contains binary extensions.
    • Use twine for uploading distributions to PyPI.

    第三方库安装路径

    Debian系的特殊路径:Link

    dist-packages instead of site-packages. Third party Python software installed from Debian packages goes into dist-packages, not site-packages. This is to reduce conflict between the system Python, and any from-source Python build you might install manually.

    就是说从源代码手动安装,将使用site-packages目录。第三方python软件安装到dist-packages目录,这是为了减少与操作系统版本的python的冲突,因为Debian系统的许多工具都依赖与系统版本的python。

    查找 Python 安装路径

    >>> from distutils.sysconfig import get_python_lib
    >>> print(get_python_lib())
    
  • 相关阅读:
    XML常用操作
    关于C#的单斜杆和双斜杆
    XX驱动保护之KdDisableDebugger
    提供程序未返回 ProviderManifestToken 字符串 解决方案
    C# int转short
    C#_混淆/反混淆,逆向/反逆向之Dotfuscator
    mouseout和mouseover、mouseenter和mouseleave
    输入法下keypress、keyup失效的解决方案
    linux常用基本命令
    如何把已完成的项目部署到服务器
  • 原文地址:https://www.cnblogs.com/weaming/p/5070873.html
Copyright © 2011-2022 走看看