python的构建工具——setup.py文件

一、构建工具setup.py的应用场景

在安装python的相关模块和库时,我们一般使用“pip install  模块名”或者“python setup.py install”,前者是在线安装,会安装该包的相关依赖包;后者是下载源码包然后在本地安装,不会安装该包的相关依赖包。所以在安装普通的python包时,利用pip工具相当简单。但是在如下场景下,使用python setup.py install会更适合需求:


在编写相关系统时,python 如何实现连同依赖包一起打包发布?

假如我在本机开发一个程序,需要用到python的redis、mysql模块以及自己编写的redis_run.py模块。我怎么实现在服务器上去发布该系统,如何实现依赖模块和自己编写的模块redis_run.py一起打包,实现一键安装呢?同时将自己编写的redis_run.py模块以exe文件格式安装到python的全局执行路径C:\Python27\Scripts下呢?

在这种应用场景下,pip工具似乎派不上了用场,只能使用python的构建工具setup.py了,使用此构建工具可以实现上述应用场景需求,只需在 setup.py 文件中写明依赖的库和版本,然后到目标机器上使用python setup.py install安装。

二、setup.py介绍

 1 from setuptools import setup, find_packages
 2
 3 setup(
 4     name = "test",
 5     version = "1.0",
 6     keywords = ("test", "xxx"),
 7     description = "eds sdk",
 8     long_description = "eds sdk for python",
 9     license = "MIT Licence",
10
11     url = "http://test.com",
12     author = "test",
13     author_email = "[email protected]",
14
15     packages = find_packages(),
16     include_package_data = True,
17     platforms = "any",
18     install_requires = [],
19
20     scripts = [],
21     entry_points = {
22         ‘console_scripts‘: [
23             ‘test = test.help:main‘
24         ]
25     }
26 )  

setup.py各参数介绍:


--name 包名称
--version (-V) 包版本
--author 程序的作者
--author_email 程序的作者的邮箱地址
--maintainer 维护者
--maintainer_email 维护者的邮箱地址
--url 程序的官网地址
--license 程序的授权信息
--description 程序的简单描述
--long_description 程序的详细描述
--platforms 程序适用的软件平台列表
--classifiers 程序的所属分类列表
--keywords 程序的关键字列表
--packages 需要处理的包目录(包含__init__.py的文件夹)
--py_modules 需要打包的python文件列表
--download_url 程序的下载地址
--cmdclass
--data_files 打包时需要打包的数据文件,如图片,配置文件等
--scripts 安装时需要执行的脚步列表
--package_dir 告诉setuptools哪些目录下的文件被映射到哪个源码包。一个例子:package_dir = {‘‘: ‘lib‘},表示“root package”中的模块都在lib 目录中。
--requires 定义依赖哪些模块
--provides定义可以为哪些模块提供依赖
--find_packages() 对于简单工程来说,手动增加packages参数很容易,刚刚我们用到了这个函数,它默认在和setup.py同一目录下搜索各个含有 __init__.py的包。

其实我们可以将包统一放在一个src目录中,另外,这个包内可能还有aaa.txt文件和data数据文件夹。另外,也可以排除一些特定的包

find_packages(exclude=["*.tests", "*.tests.*", "tests.*", "tests"])

--install_requires = ["requests"] 需要安装的依赖包
--entry_points 动态发现服务和插件,下面详细讲

下列entry_points中: console_scripts 指明了命令行工具的名称;在“redis_run = RedisRun.redis_run:main”中,等号前面指明了工具包的名称,等号后面的内容指明了程序的入口地址。

1 entry_points={‘console_scripts‘: [
2         ‘redis_run = RedisRun.redis_run:main‘,
3 ]}

这里可以有多条记录,这样一个项目就可以制作多个命令行工具了,比如:

1 setup(
2     entry_points = {
3         ‘console_scripts‘: [
4             ‘foo = demo:test‘,
5             ‘bar = demo:test‘,
6         ]}
7 )

三、setup.py的项目示例代码

 1 #!/usr/bin/env python
 2 # coding=utf-8
 3
 4 from setuptools import setup
 5
 6 ‘‘‘
 7 把redis服务打包成C:\Python27\Scripts下的exe文件
 8 ‘‘‘
 9
10 setup(
11     name="RedisRun",  #pypi中的名称,pip或者easy_install安装时使用的名称
12     version="1.0",
13     author="Andreas Schroeder",
14     author_email="[email protected]",
15     description=("This is a service of redis subscripe"),
16     license="GPLv3",
17     keywords="redis subscripe",
18     url="https://ssl.xxx.org/redmine/projects/RedisRun",
19     packages=[‘RedisRun‘],  # 需要打包的目录列表
20
21     # 需要安装的依赖
22     install_requires=[
23         ‘redis>=2.10.5‘,
24         ‘setuptools>=16.0‘,
25     ],
26
27     # 添加这个选项,在windows下Python目录的scripts下生成exe文件
28     # 注意:模块与函数之间是冒号:
29     entry_points={‘console_scripts‘: [
30         ‘redis_run = RedisRun.redis_run:main‘,
31     ]},
32
33     # long_description=read(‘README.md‘),
34     classifiers=[  # 程序的所属分类列表
35         "Development Status :: 3 - Alpha",
36         "Topic :: Utilities",
37         "License :: OSI Approved :: GNU General Public License (GPL)",
38     ],
39     # 此项需要,否则卸载时报windows error
40     zip_safe=False
41 )

参考博客:

http://blog.csdn.net/lynn_kong/article/details/17540207

http://blog.csdn.net/pfm685757/article/details/48651389

http://blog.csdn.net/langb2014/article/details/53114341

时间: 2024-10-11 17:00:41

python的构建工具——setup.py文件的相关文章

python的setup.py文件

最近工作需要,用Cython写了*.pyx扩展,并将其编译成C文件,最后转换为so扩展,供python引用 使用 distutils 编译,建立一个setup.py 的脚本 from distutils.core import setup from distutils.extension import Extension from Cython.Distutils import build_ext setup( name = 'cython_build_test', cmdclass = {'b

python 编写简单的setup.py

学习python也已经有一段时间了,发现python作为脚本语言一个很重要的特点就是简单易用,而且拥有巨多的第三方库,几乎方方面面的库都有,无论你处于哪个行业,想做什么工作,几乎都能找到对应的第三方库.别人造好了轮子,我们直接拿过来用,这大大方便了开发,也极大地提升了效率.那么问题来了,有那么多的第三方库,我们如何开发一个属于自己的库呢?其实这是一个比较大的问题,因为开发一个库涉及到的问题很多,比如这个库要用来干嘛,实现什么功能,有没有已经类似的库了,效率如何等.但是这里,我只想抛砖引玉,简单记

如何使用setup.py文件

setup.py文件的使用:% python setup.py build #编译% python setup.py install    #安装% python setup.py sdist     #制作分发包% python setup.py bdist_wininst #制作windows下的分发包% python setup.py bdist_rpm 转自: http://blog.csdn.net/ponder008/article/details/6592719/

Python模块包中__init__.py文件的作用

在eclipse中用pydev开发Python脚本时,我遇到了一个这样的现象,当我新建一个pydev package时,总会自动地生成一个空的__init__.py文件,因为是python新手,所以很不了解这个空文件的作用是什么,因为没有什么东西可写在这里,所以我直接把这个文件给删掉了,结果我的包图标自动变为文件夹图标了,这是怎么回事呢! 原来在python模块的每一个包中,都有一个__init__.py文件(这个文件定义了包的属性和方法)然后是一些模块文件和子目录,假如子目录中也有 __ini

Windows 下 Python如何执行编写的.py文件?

在Windows 系统下安装好Pyton后,直接在CMD命令提示符号里 输入CD .py的文件路径, 进入.py文件的所在目录,例如 cd c:\python33\study,进入这个目录后 输入 Python .py文件名 回车就执行了.py文件.

[python IO学习篇] 补充.py文件是中文, .ini文件内容是中文

1 python 代码文件的编码.py文件默认是ASCII编码,中文在显示时会做一个ASCII到系统默认编码的转换,这时就会出错:SyntaxError: Non-ASCII character.需要在代码文件的第一行或第二行添加编码指示: 1 # coding=utf-8 ##以utf-8编码储存中文字符 2 print '中文' 像上面那样直接输入的字符串是按照代码文件的编码来处理的,如果 用unicode编码,有以下三种方式: 1 s1 = u'中文' #u表示用unicode编码方式储存

python 通过下载包setup.py安装模块

下载安装包,并解压到相应的位置 1.打开cmd 2.到达安装目录 3.python setup.py build 4.python setup.py install 原文地址:https://www.cnblogs.com/liuchunxiao83/p/11207340.html

python基础.CMD运行命令|?.py文件

1.CMD运行python命令 cmd中输入"python",回车,进入python控制台,然后输入一些python语句 2.cmd运行?.py文件 cmd中输入"python ???.py",回车. 3. 4. 5. 原文地址:https://www.cnblogs.com/pythonzc/p/12349620.html

【python】如何在某.py文件中调用其他.py内的函数

假设名为A.py的文件需要调用B.py文件内的C(x,y)函数 假如在同一目录下,则只需 import B if __name__ == "__main__": B.C(x,y) 若只需调用单个函数,也可以 from B import C if __name__ == "__main__": C(x,y) 若A.py和B.py位于不同的目录下,可以用以下方法 (假设B.py位于D盘的根目录下) 1.引用所在路径 import sys sys.path.append(