Python package project
使用 Python 书写项目打包程序(已经存在 shell 的脚本,经过对比 Python 脚本的执行过程更加的可控人性化实现的功能相同)
- #!/usr/bin/env python
- # _*_coding:utf-8_*_
- # author: 'Edward.Liu'
- # dateTime: '15/12/9'
- # motto: 'Good memory as bad written'
- import datetime, time
- import os
- import shutil
- import subprocess
- import tarfile
- class Packages(object):
- def __init__(self):
- self.SVN_Checked_Directory = "/install/online/"
- self.Project_Directory_F = "%scybershop-front/target" % self.SVN_Checked_Directory
- self.Project_Directory_B = "%scybershop-web/target" % self.SVN_Checked_Directory
- self.Upload_Directory = "/software/backwar/"
- self.Project_Directory_F_Name = "cybershop-front-0.0.1-SNAPSHOT.war"
- self.Project_Directory_B_Name = "cybershop-web-0.0.1-SNAPSHOT.war"
- self.density_name = ['pro', 'demo', 'ptest']
- self.bulid_home = "/install/maven/bin/mvn"
- self.date_time = datetime.datetime.now().strftime('%Y-%m-%d-%H')
- def Subervison_Check(self):
- global SVN_NUMBER
- try:
- while True:
- SVN_NUMBER = raw_input("\033[32mPleae Input SVN Update Number:\033[0m").strip()
- if SVN_NUMBER.isdigit():
- SVN_NUMBER = int(SVN_NUMBER)
- if os.path.exists(self.SVN_Checked_Directory):
- print "------------------------------"
- os.chdir(self.SVN_Checked_Directory)
- svn_update = "/usr/bin/svn update -r %s" % SVN_NUMBER
- subprocess.call(svn_update, shell=True)
- break
- else:
- print "++++++++++++++++++++++++++++++"
- os.makedirs(self.SVN_Checked_Directory)
- os.chdir(self.SVN_Checked_Directory)
- svn_update = "/usr/bin/svn update -r %s" % SVN_NUMBER
- subprocess.call(svn_update, shell=True)
- break
- else:
- print "\033[31mPlease SVN Number\033[0m"
- except KeyboardInterrupt:
- print 'ctrl+d or z'
- def Bulid(self):
- global env
- # 编译项目(分环境)
- # 获取生成项目的文件名-- get
- bulided_File_Path_F = "%s/%s" % (self.Project_Directory_F, self.Project_Directory_F_Name)
- # ---get end
- # 编译环境选择--- select---> Maven
- for index, value in enumerate(self.density_name):
- print index, "Carrefour" + "---->" + value
- try:
- while True:
- Chose_ENV = raw_input("\033[32mChose Density Environment:\033[0m")
- if Chose_ENV.isdigit():
- Chose_ENV = int(Chose_ENV)
- env = self.density_name[Chose_ENV]
- try:
- if self.density_name[Chose_ENV] == 'pro':
- os.chdir(self.SVN_Checked_Directory)
- bulid_command = "%s clean install -PcarrefourPro -DskipTests" % self.bulid_home
- subprocess.call(bulid_command, shell=True)
- if os.path.isfile(bulided_File_Path_F):
- print "\033[32mBulid %s SuccessFul\033[0m" % self.density_name[Chose_ENV]
- print "\033[32m--------------------Create TarFiles--------------------\033[0m"
- self.Files_Handle()
- break
- elif self.density_name[Chose_ENV] == 'demo':
- os.chdir(self.SVN_Checked_Directory)
- bulid_command = "%s clean install -Pcarrefour -DskipTests" % self.bulid_home
- subprocess.call(bulid_command, shell=True)
- if os.path.isfile(bulided_File_Path_F):
- print "\033[32mBulid %s SuccessFul\033[0m" % self.density_name[Chose_ENV]
- print "\033[32m--------------------Create TarFiles--------------------\033[0m"
- self.Files_Handle()
- break
- elif self.density_name[Chose_ENV] == 'ptest':
- os.chdir(self.SVN_Checked_Directory)
- bulid_command = "%s clean install -PcarrefourPtest -DskipTests" % self.bulid_home
- subprocess.call(bulid_command, shell=True)
- if os.path.isfile(bulided_File_Path_F):
- print "\033[32mBulid %s SuccessFul\033[0m" % self.density_name[Chose_ENV]
- print "\033[32m--------------------Create TarFiles--------------------\033[0m"
- self.Files_Handle()
- break
- except IndexError:
- print "\033[31mSelect error\033[0m"
- except KeyboardInterrupt:
- print "\033[32m Quit\033[0m"
- # select----Maven--->END
- def Files_Handle(self):
- # 生成文件处理
- # 文件压缩----tar
- Tmp_density_dir = "/software/%s%s-%s" % (env, SVN_NUMBER, self.date_time)
- os.makedirs(Tmp_density_dir)
- source_fiels = ["%s/%s" % (self.Project_Directory_F, self.Project_Directory_F_Name),
- "%s/%s" % (self.Project_Directory_B, self.Project_Directory_B_Name)]
- for i in range(2):
- shutil.move(source_fiels[i], Tmp_density_dir)
- # 创建压缩包
- os.chdir("/software")
- tarfile_name = "%s.tar.gz" % Tmp_density_dir.split('/')[2]
- tar = tarfile.open(tarfile_name, "w:gz")
- tar.add(Tmp_density_dir.split('/')[2])
- tar.close()
- # 创建压缩包---end
- if os.path.exists(tarfile_name):
- print "\033[32m----------Delete Temporary Files%s----------\033[0m" % datetime.datetime.now().strftime(
- '%Y-%m-%d %H:%M:%S %f')
- shutil.rmtree(Tmp_density_dir)
- shutil.move(tarfile_name, self.Upload_Directory)
- Upload_Files_Name = "%s%s" % (self.Upload_Directory, tarfile_name)
- print "\033[32mSuccessful Download address:URL/%s\033[0m" % tarfile_name
- else:
- print "\033[31m----------Create archive Is Failed%s----------\033[0m" % datetime.datetime.now().strftime(
- '%Y-%m-%d %H:%M:%S %f')
- # 删除临时文件
- print "\033[32m---------Remove the compiled file%s----------\033[0m" % datetime.datetime.now().strftime(
- '%Y-%m-%d %H:%M:%S %f')
- if os.path.exists(Upload_Files_Name):
- os.chdir("/software")
- find_tmp = "find %s -name target" % self.SVN_Checked_Directory
- porc = subprocess.Popen(find_tmp, shell=True, stdout=subprocess.PIPE)
- export, err = porc.communicate()
- out_files = open("path_list.txt", "w")
- out_files.write(export)
- out_files.close()
- fileHandle = open('path_list.txt')
- for line in fileHandle.readlines():
- print "\033[31mRemove Target\033[0m", line
- shutil.rmtree(line.strip('\n'))
- fileHandle.close()
- os.remove("path_list.txt")
- # 删除文件----end
- def usage(self):
- script_name = "packages.py"
- print "\033[31m*****************************************\033[0m"
- print "\033[31m|------------Packages Useage------------|\033[0m"
- print "\033[32m|------------./%s--------------|\033[0m" % script_name
- print "\033[32m|------------<path>/%s---------|\033[0m" % script_name
- print "\033[32m|----------脚本执行过程2部人工干预------|\033[0m"
- print "\033[32m|----------1.收到输入 SVN 版本号--------|\033[0m"
- print "\033[32m|----------2.选择需要打包的环境---------|\033[0m"
- print "\033[32m|----------3.复制输出下载链接进行下载---|\033[0m"
- print "\033[31m******************************************\033[0m"
- if __name__ == '__main__':
- Run_packages = Packages()
- Run_packages.usage()
- Run_packages.Subervison_Check()
- Run_packages.Bulid()
Python package project的更多相关文章
- graphterm 0.40.1 : Python Package Index
graphterm 0.40.1 : Python Package Index graphterm 0.40.1 Downloads ↓ A Graphical Terminal Interface ...
- How to using PyPI publish a Python package
How to using PyPI publish a Python package PyPI & Python package https://pypi.org/ main make a f ...
- 使用NuGet Package Project快速制作NuGet包
今天在visual studio gallery发现了一个插件NuGet Package Project,通过它可以在Visual Studio中建立Nuget Package工程,直接生成Nuget ...
- Ghost.py 0.1b3 : Python Package Index
Ghost.py 0.1b3 : Python Package Index Ghost.py 0.1b3 Download Ghost.py-0.1b3.tar.gz Webkit based web ...
- pyrailgun 0.24 : Python Package Index
pyrailgun 0.24 : Python Package Index pyrailgun 0.24 Download pyrailgun-0.24.zip Fast Crawler For Py ...
- qrcode 4.0.4 : Python Package Index
qrcode 4.0.4 : Python Package Index qrcode 4.0.4 Download qrcode-4.0.4.tar.gz QR Code image generato ...
- bottle-session 0.3 : Python Package Index
bottle-session 0.3 : Python Package Index bottle-session 0.3
- bottle-session 0.2 : Python Package Index
bottle-session 0.2 : Python Package Index bottle-session 0.2 Download bottle-session-0.2.tar.gz Redi ...
- django-cookieless 0.7 : Python Package Index
django-cookieless 0.7 : Python Package Index django-cookieless 0.7 Download django-cookieless-0.7.ta ...
随机推荐
- Matlab矩阵间快速赋值方法
目前还没见到网上用过这个简单的方式 A= [1 2 3; 4 5 6; 7 8 9] B = zeros(5,5) B(1:3, 2:4) = A %将A赋值到B的第1行到3行,第2列岛4列, ...
- Python实用笔记 (10)高级特性——生成器
通过列表生成式,我们可以直接创建一个列表.但是,受到内存限制,列表容量肯定是有限的.而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面几个元素,那后面绝大多数元素 ...
- ajax前后端交互原理(6)
6.XMLHttpRequest对象 XMLHttpRequest 是一个 API,它为客户端提供了在客户端和服务器之间传输数据的功能.它提供了一个通过 URL 来获取数据的简单方式,并且不会使整个页 ...
- C#/VB.NET 在PDF中添加文件包(Portfolio)
PDF文件包(Portfolio)允许用户将多种不同类型的文件如Word.Excel.PDF.PowerPoint和图片等集合到一个PDF文件中,用户可以打开.更改PDF文件包中的单个文件.添加文件包 ...
- 【总结】LINQ查询基本操作列表
每个LINQ查询都以from子句开始,from子句包括以下两个功能. 指定查询将采用数据源. 定义一个本地变量,表示数据源中单个元素. string[] values = { "中国&quo ...
- JavaScript基础Literal 与 Constructor(008)
JavaScript支持以字面声名法(Literal)的方式来声名对象和数组,相对于构造函数(constructor)的方式,Literal的声 名方式更简洁,更易读,也更少导致Bug.事实上,JSO ...
- 洛谷 P1194 【买礼物】
这道题其实就是转化一个模型就可以了. 买了一个另外一个又优惠,其实就相当于在优惠的时候连一条边,因为不可能多买,所以就是建一棵最小生成树.最后因为肯定买了一件物品,要加上最初的单价. 代码: #inc ...
- css3盒子模型中的box-sizing属性的使用_box sizing常用的3种属性
box-sizing属性用来定义元素的width和height所表示的区域,该属性一般有三种值:content-box.border-box.inherit.其中inherit表示box-sizing ...
- 洛谷 P4910 帕秋莉的手环
题意 多组数据,给出一个环,要求不能有连续的\(1\),求出满足条件的方案数 \(1\le T \le 10, 1\le n \le 10^{18}\) 思路 20pts 暴力枚举(不会写 60pts ...
- 「线段树」「单点修改」洛谷P1198 [JSOI2008]最大数
「线段树」「单点修改」洛谷P1198 [JSOI2008]最大数 题面描述 现在请求你维护一个数列,要求提供以下两种操作: 1. 查询操作. 语法:Q L 功能:查询当前数列中末尾L个数中的最大的数, ...