经常接触Python的同学可能会注意到,当需要安装第三方python包时,可能会用到easy_install命令。easy_install是由PEAK(Python Enterprise Application Kit)开发的setuptools包里带的一个命令,它用来安装egg包。egg包是目前最流行的python应用打包部署方式。如何制作和安装egg包?下面我就简单的分析了一下。

1.1   安装setuptools

首先要安装setuptools工具。Debian/Ubuntu下可以直接使用apt安装::

  1. $ sudo yum install python-setuptools

1.2   制作自己的egg包

总是安装别人的egg包,是不是也想制作自己的egg包呢?好,接下来我们就自己制作一个简单的egg包。 首先建立工程目录egg-demo,初始化一个setup.py文件:

  1. $ mkdir egg-demo
  2. $ cd egg-demo
  3. $ touch setup.py
  4. $ ls
  5. setup.py

下面主要就是填充setup.py。setup.py其实是python工具包distutils的配置文件,setuptools就是基于distutils来做的。 在setup.py中通过setup函数来配置打包信息。首先要引入setuptools的函数setup。setuptools的setup其实就是distutils的setup函数,填写setup.py为以下内容:

  1. $ vim setup.py
  2. #!/usr/bin/env python
  3. #-*- coding:utf-8 -*-
  4. from setuptools import setup
  5. setup()

在setup.py中,setup函数接收一系列属性作为配置参数。

  • name name是egg包的名称,也是寻找要打包的文件夹的名称,默认是UNKNOWN。
  • version 版本号,默认0.0.0
  • packages 这里要用到setuptools的另一个函数find_packages,顾名思义,find_packages用来将指定目录下的文件打包。
  • zip_safe 默认是False,这样在每次生成egg包时都会检查项目文件的内容,确保无误。

还有一些描述性的属性,如description,long_description,author,author_email,license,keywords,platform,url等。 填充setup.py文件如下::

  1. $ cat setup.py
  2. #! /usr/bin/env python
  3. # -*- coding: utf-8 -*-
  4. from __future__ import with_statement
  5. try:
  6. from setuptools import setup,find_packages
  7. except ImportError:
  8. from distutils.core import setup
  9. #-----ignore begin------
  10. import os
  11. import sys
  12. if sys.version_info <= (2, 5) or sys.version_info >= (2, 8):
  13. error = "ERROR: UpYun SDK requires Python Version 2.6 or 2.7 ... exiting\n"
  14. sys.stderr.write(error)
  15. sys.exit(1)
  16. #-----ignore end--------
  17. setup(
  18. name='uprsync',   #包的名称,也就是你install后,从别的python文件中导入的文件包的名称,即import uprsync;
  19. version= '0.1.0',  #版本号
  20. description='UpYun Storage SDK for Python',   #包的描述
  21. license='License :: OSI Approved :: MIT License', #遵循的协议
  22. platforms='Platform Independent',
  23. author='glcsnz123',   #作者
  24. author_email='zheyun.zhong@upai.com',   #邮箱
  25. url='',                                   #链接
  26. packages=find_packages('src'),           #此处为你要整合的包的位置,find_packages()是查找给定路径下的文件,在__init__.py中需要依靠他来找到包。
  27. package_dir = {'':'src'},                #和上面的find_packages()一同使用
  28. keywords=['uprsync', 'python', 'sdk'],     #关键字
  29. #以下可忽视
  30. classifiers=[
  31. 'Development Status :: 5 - Production/Stable',
  32. 'Intended Audience :: Developers',
  33. 'License :: OSI Approved :: MIT License',
  34. 'Operating System :: OS Independent',
  35. 'Programming Language :: Python',
  36. 'Programming Language :: Python :: 2',
  37. 'Programming Language :: Python :: 2.6',
  38. 'Programming Language :: Python :: 2.7',
  39. ],
  40. )

在egg-demo目录下建立和上述name名称相同的目录uprsync,将所要打包的py文件放置在改目录下,并在uprsync目录下写__init__.py文件:

  1. $ mkdir uprsync
  2. $ vim __init__.py

__init__.py:

  1. #!/usr/bin/env python
  2. #-*- coding:utf-8 -*-
  3. from UpYunrSync import UpYunUprSync
  4. from UpYunrSync import getLastModifyTime,SetLoggerLevel,InitLogger
  5. from UpYunrSync import LOGGER,LOGFILE
  6. def Printf():
  7. print "Hello World!\n"
  8. if __name__ == '__main__':
  9. pass

在__init__.py中需要对文件进行一个整合,相当于是你在导入uprsync包(此处你要将你制作的东西看成是一个包或者说是一个整体,而不能再按照之前的按文件个数来划分)的时候,就会调用该__init__.py,但并不会执行,也就是说if __name__ == '__main__':中的内容并不会被执行,但是会让导入uprsync包的文件拥有__init__.py相同的环境。下面会举例说明。

然后新建目录src,并将整个uprsync目录放置在src下面,按照上面的修改成find_packages(‘src')和package_dir={'':'src'},这样告诉setuptools在src目录下找包,而不是原来默认的工程根目录。

再执行下面的命令:

  1. python setup.py bdist_egg

然后再进行安装:

  1. $ sudo python setup.py install
  2. running install
  3. install_dir /usr/local/lib/python2.6/dist-packages/                             #行1
  4. ...
  5. creating /usr/local/lib/python2.6/dist-packages/demo-0.1.0-py2.6.egg
  6. Extracting demo-0.1.0-py2.6.egg to /usr/local/lib/python2.6/dist-packages
  7. uprsync 0.1.0 is already the active version in easy-install.pth                  #行2
  8. Installed /usr/local/lib/python2.6/dist-packages/demo-0.1.0-py2.6.egg            #行3
  9. Processing dependencies for uprsync==0.1.0
  10. Finished processing dependencies for uprsync==0.1.0
  11. #行1、2、3很重要,它关系着如果你要卸载安装的egg,就必须通过这3行信息来删除。如果刚开始不小心忘了记住,可以重新安装一遍。
  12. #下面来介绍如何删除

1.3   egg文件卸载

以python2.6版本为例,egg文件一般安装在/usr/local/lib/python2.6/dist-packages/目录下,该目录下还有一个easy-install.pth文件,用于存放安装的egg信息。:

  1. $ cd /usr/local/lib/python2.6/dist-packages
  2. $ cat easy-install.pth|grep uprsync
  3. ./uprsync-0.1.0-py2.6.egg
  4. $ ls -F|grep uprsync
  5. uprsync-0.1.0-py2.6.egg/
  6. $ rm -rf uprsync-0.0.0-py2.6.egg
  7. $ vim easy-install.pth
  8. dd: ./uprsync-0.1.0-py2.6.egg    #删除关于uprsync的信息

如果找不到上面的文件,可以通过重新安装,按照上面1.2最后部分所要求记录的点,对应于1.3的内容进行删除

python egg for centos 制作的更多相关文章

  1. 怎样制作一个 Python Egg

    from:http://liluo.org/blog/2012/08/how-to-create-python-egg/ 制作打包一个 Python Egg 并部署整个过程还蛮有意思的,下面小教程(这 ...

  2. Python 二维码制作

    Python 二维码制作 先介绍python 二维码制作的第三方库 QRCode .MyQR QRCode    生成这个二维码只用三行 import qrcode img = qrcode.make ...

  3. spark-submit python egg 解决三方件依赖问题

    假设spark里用到了purl这个三方件,https://github.com/ultrabluewolf/p.url,他还额外依赖futures这个三方件(six的话,anaconda2自带). p ...

  4. (数据科学学习手札90)Python+Kepler.gl轻松制作时间轮播图

    本文示例代码及数据已上传至我的Github仓库https://github.com/CNFeffery/DataScienceStudyNotes 1 简介 Kepler.gl作为一款强大的开源地理信 ...

  5. 使用Python的selenium库制作脚本,支持后台运行

    本文介绍如何使用Python的selenium库制作脚本.概念:       Selenium是一个用于测试网站的自动化测试工具,支持各种浏览器包括Chrome.Firefox.Safari等主流界面 ...

  6. python egg文件解压

    unzip 就可以了. 由于项目需要将某些版本的库打包,然后 sys.path.insert方式引用(避免升级包导致某些旧的系统崩掉). 在将egg文件打包时,发现不可用.但相关模块的__path__ ...

  7. Centos制作本地yum源

    本地YUM源制作 1. YUM相关概念 1.1. 什么是YUM YUM(全称为 Yellow dog Updater, Modified)是一个在Fedora和RedHat以及CentOS中的Shel ...

  8. Redhat/CentOS 制作本地yum源

    一.制作本地yum源的场景有: (1) 操作系统ISO文件是通过光驱读取的 (2) 操作系统ISO文件是通过USB设备挂载的 (3) 操作系统ISO文件是被上传到本地文件夹的形式 二. 这3种配置方式 ...

  9. (转)python 模块安装包 制作

    转自: http://testerhome.com/topics/539 用过python的同学对于python setup.py install肯定不会陌生.那么我们自己如果封装了很多的方法怎么很好 ...

随机推荐

  1. 转载:爬虫技术浅析(Python)

    http://drops.wooyun.org/tips/3915 0x00 前言 网络爬虫(Web crawler),是一种“自动化浏览网络”的程序,或者说是一种网络机器人.它们被广泛用于互联网搜索 ...

  2. roadflow asp.net工作流自定义表单

    在roadflow表单设计器不能满足很复杂的业务需求的时候,可以采用自定义表单(即表单页面自己做). 自定义表单就是自己写一个页面,包含控制器视图,然后将这个页面挂到流程上进行审批. 自定义表单分为以 ...

  3. RabbitMq初探——消息确认

    消息确认机制 前言 消息队列的下游,业务逻辑可能复杂,处理任务可能花费很长时间.若在一条消息到达它的下游,任务刚处理了一半,由于不确定因素,下游的任务处理进程 被kill掉啦,导致任务无法执行完成.而 ...

  4. python开发工具之分析

    开发工具篇之工具分析 任务:开发python程序环境:编辑器+解释器 [原始开发python] 环境:安装python (提供python解释器,命令行shell窗口,简易python编译器,第三方库 ...

  5. 微信小店调用api代码示例

    刚开始调用微信小店api的时候,可能大家会遇到问题.系统总是提示system error,归根结底还是发送的参数不正确. 下面给出几个调用例子: 例子写得不全. <?php function c ...

  6. “全栈2019”Java第八十七章:类中嵌套接口的应用场景(拔高题)

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...

  7. [bzoj3123] [SDOI2013]森林 主席树+启发式合并+LCT

    Description Input 第一行包含一个正整数testcase,表示当前测试数据的测试点编号.保证1≤testcase≤20. 第二行包含三个整数N,M,T,分别表示节点数.初始边数.操作数 ...

  8. webpack 安装

    先安装node ----去nodejs官网上下载最新稳定版 一般node上面会有npm,所以选择npm安装webpack 命令:npm install webpack -g 有时候输入该命令会失败,一 ...

  9. P4542 [ZJOI2011]营救皮卡丘

    题目链接 题意分析 我们仔细分析一下 发现题目要求用最多\(k\)条路径实现最小权覆盖 首先由于最小路径覆盖针对的是有向图 但是这是一个无向图 所以我们面向对象编程 我们维护一个数组\(d[i][j] ...

  10. mac安装gdb调试(转载)

    转载自:http://blog.plotcup.com/a/129 最近一直用go写一个项目,本想在mac上用gdb调试一下,但xcode4.6带的gdb版 本还是太低了,不支持go,只好自己安装一个 ...