1.什么是setuptools?
setuptools是Python distutils加强版的集合,它能够帮助咱们更简单的建立和分发Python包,尤为是拥有依赖关系的。用户在使用setuptools建立包时,并不须要已安装setuptools,只要一个启动模块便可。
功能亮点:
利用EasyInstall自动查找、下载、安装、升级依赖包
建立Python Eggs
包含包目录内的数据文件
自动包含包目录内的全部的包,而不用在setup.py中列举
自动包含包内和发布有关的全部相关文件,而不用建立一个MANIFEST.in文件
自动生成通过包装的脚本或Windows执行文件
支持Pyrex,即在能够setup.py中列出.pyx文件,而最终用户无须安装Pyrex
支持上传到PyPI
能够部署开发模式,使项目在sys.path中
用新命令或setup()参数扩展distutils,为多个项目发布/重用扩展
在项目setup()中简单声明entry points,建立能够自动发现扩展的应用和框架
总之,setuptools就是比distutils好用的多,基本知足大型项目的安装和发布python
2.安装setuptools
1) 最简单安装,假定在ubuntu下
sudo apt-get install python-setuptools
2) 启动脚本安装
wget http://peak.telecommunity.com/dist/ez_setup.py
sudo python ez_setup.pylinux
3.建立一个简单的包
有了setuptools后,建立一个包基本上是无脑操做
cd /tmp
mkdir demo
cd demoubuntu
四、在demo中建立一个setup.py文件,写入以下内容:
from setuptools import setup, find_packages
setup(
name = "demo",
version = "0.1",
packages = find_packages(),
)框架
五、执行python setup.py bdist_egg便可打包一个test的包
demo
|-- build
| -- bdist.linux-x86_64 |-- demo.egg-info | |-- dependency_links.txt | |-- PKG-INFO | |-- SOURCES.txt |
-- top_level.txt
|-- dist
| -- demo-0.1-py2.7.egg
-- setup.py
在dist目录下生成的是egg包
生成的.egg文件,改为zip扩展名,解开看看先
upzip -l dist/demo-0.1-py2.7.egg函数
Archive: dist/demo-0.1-py2.7.egg
Length Date Time Name
--------- ---------- ----- ----
1 2013-06-07 22:03 EGG-INFO/dependency_links.txt
1 2013-06-07 22:03 EGG-INFO/zip-safe
120 2013-06-07 22:03 EGG-INFO/SOURCES.txt
1 2013-06-07 22:03 EGG-INFO/top_level.txt
176 2013-06-07 22:03 EGG-INFO/PKG-INFO
--------- -------
299 5 files
包里面是一系列自动生成的文件测试
六、setup() 函数可用参数解释
name
egg name
name = "HelloWorld"ui
version = "0.1"
版本号
version = "0.1"url
packages
所要包含的package(包含__init__.py的文件夹),find_packages() 函数在后面会有解释
packages = find_packages()
package_dir
所要搜索的 package 路径,这个须要与 find_packages() 中的参数成对使用,详见后面的测试code
scripts
指定python源码文件
scripts = ['say_hello.py']ip
install_requires
install_requires = ['docutils>=0.3']
package_data
所要包含的包中的文件,格式为:
package name : [file name],当 package name 为空时,表明全部包,file name 能够为 .txt 之类的表达。具体能够看右边的例子
package_data = {
If any package contains .txt or .rst files, include them用以下命令:
'': ['.txt', '.rst'],
And include any .msg files found in the 'hello' package, too用以下命令:
'hello': ['*.msg']
}
author
author = "Me"
author_email
author_email = "me@example.com"
description
description = "This is an Example Package"
license
license = "PSF"
keywords
keywords = "hello world example examples"
url 项目主页(home page) url = "http://example.com/HelloWorld/"