浅析python打包工具distutils、setuptools


Posted in Python onApril 20, 2018

python中安装包的方式有很多种:

  1. 源码包:python setup.py install
  2. 在线安装:pip install 包名(linux) / easy_install 包名(window)

python包在开发中十分常见,一般的使用套路是所有的功能做一个python模块包,打包模块,然后发布,安装使用。打包和安装包就是最常见的工作。学习中遇到distutils和setuptools两种打包的工具,学习之后做笔记记录。

distutils

distutils 是 python 标准库的一部分,这个库的目的是为开发者提供一种方便的打包方式, 同时为使用者提供方便的安装方式。当我们开发了自己的模块之后,使用distutils的setup.py打包。

一、完成功能python

浅析python打包工具distutils、setuptools

hello.py

def hello_fun():
 print "i say hello to you"

二、建立setup.py文件

setup.py

from distutils.core import setup
setup(
 name="hello_module",
 version="1.0",
 author="ljk",
 author_email="wilber@sh.com",
 py_modules=['hello'],
)

三、执行打包命令

浅析python打包工具distutils、setuptools

再次查看当前目录下自动生成了一个文件夹dist,文件夹中有一个压缩包即为我们的目标文件。另外有一个记录文件MANIFEST。

浅析python打包工具distutils、setuptools

四、安装模块

hello_module-1.0.tar.gz 是生成的python模块。切换到的我的python虚拟环境中,安装该模块。

浅析python打包工具distutils、setuptools

浅析python打包工具distutils、setuptools

使用python setup.py install 安装该模块。从路径可以看出,该模块安装到标准库的制定路径下。

浅析python打包工具distutils、setuptools

五、使用模块

 安装好模块之后,在python的交互环境中导入模块。模块就是hello.py文件,引用hello.py文件中的hello_fun()函数。

浅析python打包工具distutils、setuptools

setuptools

setuptools是distutils的增强版。setuptools有一个entry_points功能很方便,类似linux启动某个服务,如在linux命令行里firefox能启动火狐浏览器。

首先检验没有安装之前,命令path没有作用。

浅析python打包工具distutils、setuptools

 一、创建功能包

创建一个文件夹demo,在文件夹里创建get_path.py和__init__.py两个文件。get_path.py是功能函数,__init__.py是包的标识文件。

浅析python打包工具distutils、setuptools

get_path.py

import os
def fun():
 print "i am in the path:"
 print os.getcwd()

二、配置setup.py文件

创建setup.py文件,填写必要的打包信息。

 setup.py

#-*- encoding: UTF-8 -*-
from setuptools import setup
setup(
 name = "demo",    # 包名
 version = "0.1",    # 版本信息
 packages = ['demo'],   # 要打包的项目文件夹
 include_package_data=True, # 自动打包文件夹内所有数据
 zip_safe=True,    # 设定项目包为安全,不用每次都检测其安全性
 install_requires = [   # 安装依赖的其他包(测试数据)
 'docutils>=0.3',
 'requests',
 ],
 # 设置程序的入口为path
 # 安装后,命令行执行path相当于调用get_path.py中的fun方法
 entry_points={
  'console_scripts':[
   'path = demo.get_path:fun'
          ]
 },
)
<br data-filtered="filtered"><br data-filtered="filtered">

在配置中将该模块需要的依赖全部都写好,安装时指定地址去下载。这种方式简化了使用时的安装过程,但是还不够好。最好的方式是pip的自动下载。

三、打包

浅析python打包工具distutils、setuptools 

打包之后多出两个文件夹,分别是demo.egg-info和dist。demo.egg-info是必要的安装信息,而dist中的压缩包就是安装包。

浅析python打包工具distutils、setuptools

 查看dist/demo-0.1.tar.gz解压之后的文件。

浅析python打包工具distutils、setuptools

四、安装包

浅析python打包工具distutils、setuptools

五、使用包

安装之后在命令行中直接输入path,回车能够看到调用了get_path.py中的函数fun(),输出字符串。

浅析python打包工具distutils、setuptools

同时也可以导入使用。

浅析python打包工具distutils、setuptools

 setuptools的进阶使用

上面使用setuptools时只是简单的用一个配置文件setup.py就完成了打包信息填写。在真实的开发环境中,往往是多个文件配合。以openstack的打包为例。openstack中引入了Pbr的管理工具。

pbr是setuptools的辅助工具,最初为openstack开发,基于d2to1。Pbr会读取和过滤setup.cfg中的内容,然后将解析后的数据提供给setup.py作为参数。

setup.cfg提供setup.py的默认参数,同时易于修改。Setup.py先解析setup.cfg文件,然后执行相关命令。包括以下功能:

1、从git中获取Version,AUTHORS和ChangeLog信息

2、SphinxAutodoc。pbr会扫描project,找到所有模块,生成stubfiles

3、Requirements。读取requirements.txt文件,生成setup函数需要依赖包

4、long_description。从README.rst、README.txt或者READMEfile中生成long_description参数

Pbr的文件很简单,如下。配置之后会自动寻找目录下的setup.cfg文件,解析文件参数给setup.py使用。

setup.py

from setuptools import setup
setuptools.setup(
setup_requires=['pbr'],
pbr=True)
setup.cfg

[metadata]
name= keystone
version= 2015.2
summary= OpenStack Identity
description-file=
README.rst
author= OpenStack
author-email= openstack-dev@lists.openstack.org
home-page= http://www.openstack.org/
classifier=
Environment:: OpenStack
IntendedAudience :: Information Technology
IntendedAudience :: System Administrators
License:: OSI Approved :: Apache Software License
OperatingSystem :: POSIX :: Linux
ProgrammingLanguage :: Python
ProgrammingLanguage :: Python :: 2
ProgrammingLanguage :: Python :: 2.7
[files]
packages=
keystone
[global]
setup-hooks=
pbr.hooks.setup_hook
[egg_info]
tag_build=
tag_date= 0
tag_svn_revision= 0
[build_sphinx]
all_files= 1
build-dir= doc/build
source-dir= doc/source
[compile_catalog]
directory= keystone/locale
domain= keystone

总结

以上所述是小编给大家介绍的python打包工具distutils、setuptools ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Python 相关文章推荐
Python3中常用的处理时间和实现定时任务的方法的介绍
Apr 07 Python
python中json格式数据输出的简单实现方法
Oct 31 Python
理解python中生成器用法
Dec 20 Python
Python中的单行、多行、中文注释方法
Jul 19 Python
python将字符串以utf-8格式保存在txt文件中的方法
Oct 30 Python
python实现电子书翻页小程序
Jul 23 Python
pyhton中__pycache__文件夹的产生与作用详解
Nov 24 Python
Python3 实现爬取网站下所有URL方式
Jan 16 Python
PYcharm 激活方法(推荐)
Mar 23 Python
Python应用实现双指数函数及拟合代码实例
Jun 19 Python
基于Python和C++实现删除链表的节点
Jul 06 Python
一篇文章搞懂python的转义字符及用法
Sep 03 Python
PyQt5每天必学之切换按钮
Aug 20 #Python
PyQt5每天必学之滑块控件QSlider
Apr 20 #Python
PyQt4实现下拉菜单可供选择并打印出来
Apr 20 #Python
PyQt5每天必学之组合框
Apr 20 #Python
python 时间信息“2018-02-04 18:23:35“ 解析成字典形式的结果代码详解
Apr 19 #Python
Pyqt实现无边框窗口拖动以及窗口大小改变
Apr 19 #Python
Python利用pandas计算多个CSV文件数据值的实例
Apr 19 #Python
You might like
让Json更懂中文(JSON_UNESCAPED_UNICODE)
2011/10/27 PHP
PHP 文件编程综合案例-文件上传的实现
2013/07/03 PHP
PHP使用json_encode函数时不转义中文的解决方法
2014/11/12 PHP
php中return的用法实例分析
2015/02/28 PHP
php取出数组单个值的方法
2018/03/12 PHP
thinkPHP事务操作简单案例分析
2019/10/17 PHP
js中将HTMLCollection/NodeList/伪数组转换成数组的代码
2011/07/31 Javascript
js对象关系图 方便dom操作
2012/03/18 Javascript
poshytip 基于jquery的 插件 主要用于显示微博人的图像和鼠标提示等
2012/10/12 Javascript
利用js的Node遍历找到repeater的一个字段实例介绍
2013/04/25 Javascript
nodejs命令行参数处理模块commander使用实例
2014/09/17 NodeJs
js仿百度切换皮肤功能(html+css)
2016/07/10 Javascript
原生js仿jquery animate动画效果
2016/07/13 Javascript
vue2 自定义动态组件所遇到的问题
2017/06/08 Javascript
js 概率计算(简单版)
2017/09/12 Javascript
mongoose更新对象的两种方法示例比较
2017/12/19 Javascript
Vue-cli3简单使用(图文步骤)
2019/04/30 Javascript
vue设置全局访问接口API地址操作
2020/08/14 Javascript
Python实现把xml或xsl转换为html格式
2015/04/08 Python
使用C语言扩展Python程序的简单入门指引
2015/04/14 Python
python动态性强类型用法实例
2015/05/09 Python
Python 函数基础知识汇总
2018/03/09 Python
python学生管理系统代码实现
2020/04/05 Python
python实现将汉字保存成文本的方法
2018/11/16 Python
Python处理session的方法整理
2019/08/29 Python
基于Python和PyYAML读取yaml配置文件数据
2020/01/13 Python
详解Python中的Lock和Rlock
2021/01/26 Python
用60行代码实现Python自动抢微信红包
2021/02/04 Python
美国在线旅行社:Crystal Travel
2018/09/11 全球购物
社区健康教育工作方案
2014/06/03 职场文书
实习科室评语
2015/01/04 职场文书
年度考核登记表个人总结
2015/03/06 职场文书
《失物招领》教学反思
2016/02/20 职场文书
七年级话题作文之执着
2019/11/19 职场文书
PHP判断是否是json字符串
2021/04/01 PHP
vue-element-admin项目导入和导出的实现
2021/05/21 Vue.js