Python 的 setup.py
背景
pip 是最主流的包管理方案,使用
pip install xxx
pip 无法正常下载Python模块,或者需要在离线环境及无网络环境安装Python包的时候,可以采用安装 .whl文件或者setup.py文件的方式。
一般的可以在下面的这个网站找到: https://pypi.org/
下载对应的包的whl文件,然后执行
pip install XXX.whl
在安装普通的python包时,利用pip工具相当简单。采用setup.py去构建环境,将自己写的模块以及相应的依赖库一起打包,用setup去完成这个任务。 所以很多github代码都提供setup.py方便我们一键安装。
如果您下载的软件包在根文件夹中具有“ setup.py”,则可以通过运行以下命令进行安装:
python setup.py install
如果你想安装一个模块但又不想安装pip,那么唯一的选择就是从setup.py文件安装模块。这可以通过python setup.py install。
什么是setup.py、setuptools
官网:Building and Distributing Packages with Setuptools
参考URL: https://setuptools.pypa.io/en/latest/setuptools.html
setup.py是一个 python 文件,它的存在表明您要安装的模块/包可能已经用 Setuptools 打包和分发,这是分发 Python 模块的标准。 它的目的是正确安装软件。
setuptools是python自带的用来构建包的工具,构建出来的wheel(.whl)可供其他人pip install和import。
总之,setuptools就是比distutils好用的多,基本满足大型项目的安装和发布!
一个最基本的”setup.py”文件如下:
from setuptools import setup
setup(name='MyApp', version='1.0', packages=['myapp']
)
什么是setuptools
setuptools官方文档:https://setuptools.readthedocs.io
distutils 是标准库中负责建立 Python 第三方库的安装器,使用它能够进行 Python 模块的安装和发布。
setuptools 是 distutils 增强版,不包括在标准库中。其扩展了很多功能,能够帮助开发者更好的创建和分发 Python 包。大部分 Python 用户都会使用更先进的 setuptools 模块。
Setuptools 提供一流的setup.py文件支持作为配置机制。setup.py 调用了 setuptools 包中的setup方法。
然而,重要的是要记住,强烈建议不要将此文件作为脚本(例如)运行,并且大多数命令行界面已经(或将要)弃用 (例如,…)。python setup.py sdistpython setup.py installpython setup.py bdist_wininst
** 我们还建议用户通过pyproject.toml
或 setup.cfg
以更具声明性的方式公开尽可能多的配置,并仅使用动态部分保持最小化(如果适用,甚至完全省略)**。setup.py有关更多背景信息,请参阅为什么不应该直接调用 setup.py 。
setup.py命令
查看所有支持的命令:
python setup.py --help-commands
构建安装时所需的所有内容:
python setup.py build
安装包到系统环境中。该命令会将当前项目安装到当前Python环境的”site-packages”目录下,这样其他项目就可以像导入标准库一样导入该项目的代码了。
python setup.py install
以开发方式安装包:
如果项目在开发过程中会频繁变更,每次安装还需要先将原来的版本卸掉,会很麻烦。使用”develop”开发方式安装的话,项目代码不会真的被拷贝到本地Python环境的”site-packages”目录下,而是在”site-packages”目录里创建一个指向当前项目位置的链接。这样如果当前位置的源码被改动,就会马上反映到”site-packages”里。
python setup.py develop
用于包的上传发布:
python setup.py register
setup.py内容
生成可执行文件的分发(安装到指定路径)
参考URL: https://amir.rachum.com/blog/2017/07/28/python-entry-points/
网上demo:
entry_points={'console_scripts': ['pmm=pimm.pimm_module:main']},
scripts=['bin/foo.sh', 'bar.py']
将python模块转变为命令行工具:
如果我们希望 module 中的函数不仅仅只是被其他 python 程序通过 import 调用,还可以直接在命令行中执行,那么可以做如下修改:(设置参数entry_points里的’console_scripts’)
import pyjokesdef greeting_func(name):print("Hello,", name)print("Here is a joke for you:\n", pyjokes.get_joke())def main():import sysarg = sys.argv[1]greeting_func(arg)
from setuptools import setup, find_packagessetup(entry_points={ 'console_scripts': ['greeting=greeting_pkg.greeting_module:main' ]}
)
引入非Python文件
如果想引入静态文件,如JS、CSS、图片等,怎么做?
在项目根目录下添加一个”MANIFEST.in”文件夹。假设我们把所有静态文件都放在”static”子目录下,
我们在清单文件”MANIFEST.in
”中,列出想要在包内引入的目录路径:
recursive-include myapp/static *
recursive-include myapp/xxx *
recursive-include表明包含子目录。
在”setup.py”中将include_package_data参数设为True:
from setuptools import setup
setup(name='MyApp', version='1.0',packages=['myapp'], include_package_data=True
)
如果你想排除一部分文件,可以在”setup.py”中使用exclude_package_date参数:
setup(...include_package_data=True, exclude_package_date={'':['.gitignore']}
)
依赖管理
我们的项目会依赖其他Python模块,如何在setup.py中管理这些依赖呢?
修改”setup.py”文件,加入install_requires参数:
from setuptools import setup
setup(name&#61;&#39;MyApp&#39;, version&#61;&#39;1.0&#39;,packages&#61;[&#39;myapp&#39;], include_package_data&#61;True, exclude_package_date&#61;{&#39;&#39;:[&#39;.gitignore&#39;]},install_requires&#61;[ &#39;Flask>&#61;0.10&#39;,&#39;Flask-SQLAlchemy>&#61;1.5,<&#61;2.1&#39;]
)
可以通过dependency_links指定依赖包下载路径。install_requires中的包在安装时会先去PyPI下载并安装&#xff0c;如果包在PyPI中找不到&#xff0c;则会从dependency_links标识的URL中获取&#xff1a;
setup(...install_requires&#61;[ &#39;Flask>&#61;0.10&#39;,&#39;Flask-SQLAlchemy>&#61;1.5,<&#61;2.1&#39;],dependency_links&#61;[ &#39;http://example.com/dependency.tar.gz&#39;]
)
路径应指向一个”egg”包或”tar.gz”包&#xff0c;也可以是个包含下载地址&#xff08;一个”egg”包或”tar.gz”包&#xff09;的页面。
编写 setup.py 文件, setup.py是python模块分发与安装的指导文件。
有了setup.py文件&#xff0c;运行下面这条命令&#xff0c;可以进行模块的安装。
与 .whl文件一样&#xff0c;先cmd到指定位置&#xff0c;然后输入&#xff1a;
python setup.py install
安装
$ pip install setuptools