使用 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的更多相关文章

  1. graphterm 0.40.1 : Python Package Index

    graphterm 0.40.1 : Python Package Index graphterm 0.40.1 Downloads ↓ A Graphical Terminal Interface ...

  2. 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 ...

  3. 使用NuGet Package Project快速制作NuGet包

    今天在visual studio gallery发现了一个插件NuGet Package Project,通过它可以在Visual Studio中建立Nuget Package工程,直接生成Nuget ...

  4. 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 ...

  5. pyrailgun 0.24 : Python Package Index

    pyrailgun 0.24 : Python Package Index pyrailgun 0.24 Download pyrailgun-0.24.zip Fast Crawler For Py ...

  6. 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 ...

  7. bottle-session 0.3 : Python Package Index

    bottle-session 0.3 : Python Package Index bottle-session 0.3

  8. 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 ...

  9. django-cookieless 0.7 : Python Package Index

    django-cookieless 0.7 : Python Package Index django-cookieless 0.7 Download django-cookieless-0.7.ta ...

随机推荐

  1. 洛谷P3694 邦邦的大合唱站队【状压dp】

    状压dp 应用思想,找准状态,多考虑状态和\(f\)答案数组的维数(这个题主要就是找出来状态如何转移) 题目背景 \(BanG Dream!\)里的所有偶像乐队要一起大合唱,不过在排队上出了一些问题. ...

  2. css与javascript重难点,学前端,基础不好一切白费!

    JavaScript是一种属于网络的脚本语言,已经被广泛用于Web应用开发,常用来为网页添加各式各样的动态功能,为用户提供更流畅美观的浏览效果.通常JavaScript脚本是通过嵌入在HTML中来实现 ...

  3. 命令 关闭SElinux

    # sed -i 's/^SELINUX=.*$/SELINUX=disabled/g' /etc/selinux/config

  4. 如何白嫖微软Azure12个月及避坑指南

    Azure是微软提供的一个云服务平台.是全球除了AWS外最大的云服务提供商.Azure是微软除了windows之外另外一个王牌,微软错过了移动端,还好抓住了云服务.这里的Azure是Azure国际不是 ...

  5. Mysql中Union和OR性能对比

    博客已搬家,更多内容查看https://liangyongrui.github.io/ Mysql中Union和OR性能对比 在leetcode上看到一篇文章,整理一下 参考:https://leet ...

  6. 洛谷 P1640 SCOI2010 连续攻击游戏 并查集

    题目描述 lxhgww最近迷上了一款游戏,在游戏里,他拥有很多的装备,每种装备都有2个属性,这些属性的值用[1,10000]之间的数表示.当他使用某种装备时,他只能使用该装备的某一个属性.并且每种装备 ...

  7. Java 基础 —— Lambda 表达式

    概述 阅读项目代码时,尤其是阅读一些源码时,经常会遇到 Lambda 表达式.对此之前看过相关文章,但是停留在模模糊糊的印象上.今天趁着有时间,通过一些 demo 示例,梳理一下它的用法,以备后期遗忘 ...

  8. C/C++编程语言制作《游戏内存外挂》

    通过C/C++编程语言编写一个简单的外挂,通过 API 函数修改游戏数据,从而实现作弊功能 对象分析要用的 API 函数简单介绍编写测试效果. 下面是我整理好的全套C/C++资料,加入天狼QQ7269 ...

  9. CTF_show平台 web题解 part2

    web10 WITH ROLLUP 绕过 点击取消键弹出源码下载: 源码如下: <?php $flag=""; function replaceSpecialChar($st ...

  10. (四)pandas的拼接操作

    pandas的拼接操作 #重点 pandas的拼接分为两种: 级联:pd.concat, pd.append 合并:pd.merge, pd.join 0. 回顾numpy的级联 import num ...