经常接触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. 使用memset初始化C++自定义类型

    当类型本身或者类型的成员变量带有虚函数以及像std::vector这类复杂数据结构的时候.就会出错,原因是memset把类型本身所带的一些隐含的信息也给置0了.如:虚表指针.std::vector的内 ...

  2. Java Web系列:Hibernate 基础

    从以下5个方面学习hibernate ORM. (1)配置文件:hibernate.cfg.xml XML文件和hibernate.properties属性文件 (2)实体映射:1对多.多对多 (3) ...

  3. Cockroachdb 一、系统环境

    cockroachdb 一.系统环境 **硬件** 最低标准 a 至少3个节点保证集群可用副本 b 每个节点至少1CPU ,2GB RAM.增加资源配置可支持处理更多的数据,负载,高并发,高性能. 最 ...

  4. Buffer Pool--锁定内存页

    锁定内存页在数据库中的优点和缺点: SQL Server 使用VirtualAlloc来分配内存,无内存压力时,SQL Server会尽可能地申请内存来缓存数据,当内存出现压力时,会出现缓存数据频繁地 ...

  5. Spring学习(五)——集成MyBatis

    本篇我们将在上一篇http://www.cnblogs.com/wenjingu/p/3829209.html的Demo程序的基础上将 MyBatis 代码无缝地整合到 Spring 中. 数据库仍然 ...

  6. solr-4.10.2版本使用tomcat7部署

    当前版本仅限于solr-4.10.2版本.默认环境使用的是jdk1.7,tomcat7.环境自己配置.网上一堆堆的. 1.下载相应的文件(solr-4.10.2.zip). 官网地址:http://l ...

  7. BEAUTIFUL

    DESCRIPTION:一个长度为n 的序列,对于每个位置i 的数ai 都有一个优美值,其定义是:找到序列中最长的一段[l, r],满足l<i<r,且[l, r] 中位数为ai(我们比较序 ...

  8. WebService-php- 2(17)

    wsdl实例 <?xml version ='1.0' encoding ='UTF-8' ?> <definitions targetNamespace='http://local ...

  9. zTree第三章,异步加载,前端

    zTree异步加载 ---------------------------------------------------------------------------------- 具体详见API ...

  10. redis5.0.4-cluster集群搭建及jedis客户端操作

    一.去官网下载redis5.0 https://redis.io/download 然后解压安装 $ .tar.gz $ cd redis- $ make 二.准备配置文件 打开redis-5.0.4 ...