Show Your ToolBox——锋利的groovy

在工作中使用groovy做了很多辅助工具,这里以代码形式发出来,和喜欢groovy的童鞋们交流下

 

1. 文件操作类

1.1 清除.svn文件夹

import static groovy.io.FileType.*

new File('.').eachFileRecurse(DIRECTORIES, ~/^\.svn$/){
	it.delete()
}
 

 

1.2 在一堆jar中找一个class

 

import java.util.Enumeration
import java.util.zip.ZipEntry
import java.util.zip.ZipFile
import java.util.zip.ZipOutputStream

def findJarFile(File zipFile, String target){
	ZipFile zip = new ZipFile(zipFile)
	ZipEntry entry = null
	Enumeration<? extends ZipEntry> en = zip.entries()
	while (en.hasMoreElements()) {
		entry = en.nextElement()
		if (entry.isDirectory()) {
			continue
		}

		if(entry.name.endsWith(target)){
			println zipFile.name
			println entry
		}
	}
	zip.close()
}

String target = 'TESTMY.class'
new File('D:/lib').eachFile{
	if(it.name.endsWith('.jar'))
		findJarFile(it, target)
}

 

 

1.3 从mvn repository下载一个jar到groovy.conf的path下()

import groovy.grape.Grape

String dir_lib = System.getProperty('user.home').replaceAll("\\\\", '/') + 
	'/.groovy/lib/'
List mvn = [
	'org.apache.poi', 
	'poi', 
	'3.7'
]
Grape.grab(group:mvn[0], 
	module:mvn[1], version:mvn[2])

String jar_path = System.getProperty('user.home').replaceAll("\\\\", '/') + 
	'/.groovy/grapes/' + mvn[0] + '/' + mvn[1] + '/jars/' + mvn[1] + '-' + mvn[2] + '.jar'

def ant = new AntBuilder()
ant.copy file : jar_path, todir : dir_lib
 

1.4 比较文件夹下的文件不同

String path1 = 'D:/soft/eclipse/plugins/org.apache.ant_1.7.0.v200803061910/lib'

String path2 = 'C:/ANT_HOME/Apache-Ant-1.7.0/lib'

List ll = new File(path1).listFiles().collect{it.name}
List ll2 = new File(path2).listFiles().grep{it.name.endsWith('.jar')}.collect{it.name}

def ant = new AntBuilder()
(ll2 - ll).each{
	ant.copy todir : path1, file : path2 + '/' + it
}
 

1.5 下载一个url到本地文件(爬漫画弄个多线程,很给力的)

 

long begin = System.currentTimeMillis()
String url = 'http://**host.com/***'
new File('output.xml') << new URL(url).text
println System.currentTimeMillis() - begin

 

 

2. 用一些第三方库

2.1 jxl

import jxl.*

String path = "my.xls"
int begin_row = 1
List cols = 'a'..'l'
List ll = []

File file = new File(path)
Workbook wb =  Workbook.getWorkbook(file)
def sheet = wb.sheets[0]

for(i in begin_row..<sheet.rows){
	Map item = [:]
	cols.eachWithIndex{cc, j ->
		Cell cell = sheet.getCell(j, i)
		String content = cell.getContents()
		if(content == null)
			content = ''

		item[cc] = content
	}
	if(item[cols[0]])
		ll << item
}

// excel -> 到一个二位列表了ll,然后你就可以随心所欲了

  2.2 email

import java.security.Security;

import javax.mail.* 

final String POP3Host = '***'
final String userName = 'xx'
final String pwd = 'xxx'

Security.addProvider(new com.sun.net.ssl.internal.ssl.Provider())
def prop = System.getProperties()
prop.setProperty("mail.pop3.socketFactory.class", "javax.net.ssl.SSLSocketFactory")
prop.setProperty("mail.pop3.socketFactory.fallback", "false")
prop.put("mail.pop3.host", POP3Host)
prop.put("mail.imap.starttls.enable", "true")
prop.put("mail.debug", "true")
prop.setProperty("mail.pop3.port ", "995")
prop.setProperty("mail.pop3.socketFactory.port", "995")

def auth = [
	getPasswordAuthentication : {
		new PasswordAuthentication(userName, pwd)
	}
] as Authenticator
def s = Session.getDefaultInstance(prop, auth)
def store = s.getStore("pop3")  
store.connect(POP3Host, userName, pwd) 

Folder folder = store.getFolder("Inbox")  
folder.open(Folder.READ_ONLY) 

FetchProfile profile = new FetchProfile()  
profile.add(FetchProfile.Item.ENVELOPE) 
Message[] arr = folder.getMessages()
folder.fetch(arr, profile) 

println "收件箱的邮件数:" + arr.length  

folder.close(false) 
store.close()

 

2.3 css压缩

def ant = new AntBuilder()

String dir = 'cssjs'

ant.taskdef name: 'yuicompress', 
	classname: 'com.yahoo.platform.yui.compressor.YUICompressTask'

ant.yuicompress linebreak: 300, warn: 'false', munge: 'yes', 
	preserveallsemicolons: 'true', outputfolder: dir, {
		fileset dir: dir, {
			include name: '*.css'
		}
	}

  2.4 执行下fastjson方法

import com.alibaba.fastjson.JSON

import com.alibaba.fastjson.parser.Feature
import com.alibaba.fastjson.serializer.SerializerFeature

List ll = [[test: 'test']]
def sll = [] as SerializerFeature[]
def fll = [] as Feature[]

def bytes = JSON.toJSONBytes(ll, sll)

println JSON.parse(bytes, fll)

  2.5 jftp

import net.sf.jftp.net.* 
import net.sf.jftp.config.Settings

import org.apache.commons.io.IOUtils
   
String host = "xx"
int port = 22
String user = "xx"
String pwd = "xx"

String file = "/xx.txt"

Settings.bufferSize = 16384  
def con = new FtpConnection(host, port, "<default>")
con.setConnectionHandler(new ConnectionHandler()) 
con.login(user, pwd) 
           
InputStream is = con.getDownloadInputStream(file) 
IOUtils.copy(is, new FileOutputStream(new File(file)))
 

3. 文本分析类——这块就用起来比较多了,数据源可以是文本,excel,db,下面只贴一个我最近做的一个分析友盟(umeng.com)自定义事件的一个数据分析的代码(业务场景是ios的一个应用做一个发送、接收的动作,分析下一天中这些动作的错误情况),我贴这段代码没有实际参考价值,只能表明groovy可以做很多很多的事儿

import groovy.sql.Sql

final String format = 'yyyy-MM-dd'
final List versions = ['2.1.9', '2.2.0', 
	'2.2.1', '2.2.2', '2.2.3']
final List datRange = Date.parse(format, '2012-07-07')..Date.parse(format, '2012-07-09')
def pat = /,,,/

// 去掉第一行,取一天的数据和一个版本的数据
def ll = []
new File('umeng').eachFile{ff ->
	ll += ff.readLines()[1..-1]
}

// 中文字符对齐
def padRightGbk = {str, num ->
	return str
//	return str.padRight(num - str.bytes.size() + str.size())
}

def getLinesTarget = {dat, version ->
	def rll = ll.grep{
		it.contains(version)
	}

	if(dat)
		rll = rll.grep{it.startsWith(dat)}
	return rll
}

def printStat = {lines, version ->
	// 发送成功率统计
	def sendLl = lines.grep{
		def arr = it.split(pat)
		// 参数值
		String result = arr[2]
		return result.contains('上传开始') || 
			result.contains('上传结束')
	}.collect{
		def arr = it.split(pat)

		String dat = arr[0]
		
		// 参数值
		String result = arr[2]
		String reportId = result.split(' ')[0]
		String sendTimes = arr[4]

		String type = 'end'
		if(result.endsWith('上传开始'))
			type = 'start'

		boolean flag = false
		String typeEnd = 'endOk'

		// 发送成功,有结束返回且不是网络超时
		if(result.contains('上传结束')){
			if(result.endsWith('上传结束')){
				typeEnd = 'endOk'
				flag = true
			}else{
				if(result.contains('网络超时')){
					typeEnd = 'endTimeout'
				}else{
					typeEnd = 'endFail'
				}
			}
		}

		return [reportId: reportId, type: type, flag: flag, typeEnd: typeEnd, 
			sendTimes: Double.valueOf(sendTimes), dat: dat]
	}

	// ID列表
	def reportIdLl = sendLl.clone().collect{it.reportId}.unique().sort()
	def sendResultLl = reportIdLl.collect{reportId ->
		def llSub = sendLl.grep{it.reportId == reportId}
		// 最终发送成功的标示
		boolean isOk = llSub.any{'end' == it.type && it.flag}

		def startLl = llSub.grep{'start' == it.type}
		def endLlOk = llSub.grep{'end' == it.type && 'endOk' == it.typeEnd}
		def endLlFail = llSub.grep{'end' == it.type && 'endFail' == it.typeEnd}
		def endLlTimeout = llSub.grep{'end' == it.type && 'endTimeout' == it.typeEnd}

		int startSendTimes = 0
		if(startLl){
			startSendTimes = startLl.sum{it.sendTimes ?: 0}
		}

		int endSendTimesOk = 0
		if(endLlOk){
			endSendTimesOk = endLlOk.sum{it.sendTimes ?: 0}
		}

		int endSendTimesFail = 0
		if(endLlFail){
			endSendTimesFail = endLlFail.sum{it.sendTimes ?: 0}
		}

		int endSendTimesTimeout = 0
		if(endLlTimeout){
			endSendTimesTimeout = endLlTimeout.sum{it.sendTimes ?: 0}
		}

		return [isOk: isOk, reportId: reportId, 
			startNum: startLl.size(), 
			endNumOk: endLlOk.size(), 
			endNumFail: endLlFail.size(), 
			endNumTimeout: endLlTimeout.size(), 
			startSendTimes: startSendTimes, 
			endSendTimesOk: endSendTimesOk,
			endSendTimesFail: endSendTimesFail, 
			endSendTimesTimeout: endSendTimesTimeout, 
			dat: llSub ? llSub[0]['dat'] : '',
			version: version
			]
	}

	// 把分析出来的结果放到数据库里以利用sql进行分析
	if(sendResultLl){
		def p = [
		  url:'jdbc:h2:tcp://localhost/data/all/crashreport', 
		  u:'sa', 
		  p:'', 
		  driver:'org.h2.Driver'
		]
		def db = Sql.newInstance(p.url, p.u, p.p, p.driver)

		try {
			db.execute('''
			create table if not exists t_send_stat(
				is_ok boolean,
				report_id varchar, 
				
				start_num int,
				end_num_ok int,
				end_num_fail int,
				end_num_timeout int,
				
				start_times int,
				end_times_ok int,
				end_times_fail int,
				end_times_timeout int,

				dat date, 
				version varchar
			);
			'''
			)
			sendResultLl.each{
				db.executeInsert("""
				insert into t_send_stat values(
					?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?, ?
				)
				""",
				[it.isOk, it.reportId, 
					it.startNum, 
					it.endNumOk,
					it.endNumFail,
					it.endNumTimeout,
					it.startSendTimes,
					it.endSendTimesOk,
					it.endSendTimesFail,
					it.endSendTimesTimeout,
					it.dat,
					it.version])
			}
		}finally {
		    db.close()
		}
	}
	//def rows = new File('reportSendDept.txt').readLines().collect{
	//	def arr = it.split(pat)
	//	[REPORT_ID: arr[1], COMPANY_CODE: arr[-1]]
	//	// substring(0, 3)
	//}
	//sendResultLl.each{
	//	def item = rows.find{row -> row['REPORT_ID'] == it.reportId}
	//	it.dept = item ? item['COMPANY_CODE'] : '???'
	//}
	/*
	CREATE CACHED TABLE T_SEND_STAT(
		FLAG BOOL,
		REPORT_ID VARCHAR(20),
		NUM_START INT,
		NUM_END_OK INT,
		NUM_END_FAIL INT,
		TIMES_START INT,
		TIMES_END_OK INT,
		TIMES_END_FAIL INT,
		DEPT VARCHAR(10)
	);

	insert into T_SEND_STAT select csvread('data/reportSendDept.txt');
	*/

	// 总数
	int numAll = sendResultLl.size()
	if(!numAll)
		return

	// 发送总数
	int numOk = sendResultLl.grep{it.isOk}.size()
	int numFail = numAll - numOk

	// 无返回结果的发送
	int numFailWithNoErrorEnd = sendResultLl.grep{
		!it.isOk && it.endNumError == 0
	}.size()

	final int padNum = 30
//	print padRightGbk('总数', padNum) + ',' + numAll + ','
//	print padRightGbk('发送成功总数', padNum) + ',' + numOk + ','
//	print padRightGbk('发送失败总数', padNum) + ',' + numFail + '(其中无返回信息' + numFailWithNoErrorEnd + ')' + ','
//	print padRightGbk('发送成功率', padNum) + ',' + (numOk / numAll) + ','

	println '总数,发送成功总数,发送失败总数,其中无返回信息,发送成功率'
	print numAll
	print ','
	print numOk
	print ','
	print numFail
	print ','
	print numFailWithNoErrorEnd
	print ','
	print (numOk / numAll)
	print ','
	println ''

	// 计算消息数
	int startNum = sendResultLl.collect{it.startSendTimes ?: 1}.sum()

	// ****** ****** ****** ****** ****** ****** ****** ****** ******
	// ****** ****** ****** ****** ****** ****** ****** ****** ******
	// ****** ****** ****** ****** ****** ****** ****** ****** ******
	// 更新、发送时长统计
	def sendTimeLl = lines.grep{
		def arr = it.split(pat)
		// 参数
		String key = arr[1]
		return key in ['更新耗时', '上传耗时']
	}.collect{
		def arr = it.split(pat)

		String type = arr[1] == '上传耗时' ? 'up' : 'down'
		String secStr = arr[2]
		if(secStr.contains(':'))
			secStr = secStr.split(':')[1]

		return [type: type, sec: Double.valueOf(secStr), 
			sendTimes: Double.valueOf(arr[4])]
	}

	println '单个刷新总数,平均刷新时间,超7s次数,发送平均时长,超3分钟次数'
	if(sendTimeLl){
		def sendTimeLlDown = sendTimeLl.grep{'down' == it.type}
		if(sendTimeLlDown){
//			print padRightGbk('单个刷新总数', padNum) + ',' + sendTimeLlDown.sum{it.sendTimes ?: 0} + ','
//			print padRightGbk('平均刷新时间', padNum) + ',' + (sendTimeLlDown.sum{it.sec * it.sendTimes} / sendTimeLlDown.sum{it.sendTimes}) + ','
//			print padRightGbk('超7s次数', padNum) + ',' + sendTimeLlDown.grep{it.sec > 7}.size() + ','

			print sendTimeLlDown.sum{it.sendTimes ?: 0}
			print ','
			print (sendTimeLlDown.sum{it.sec * it.sendTimes} / sendTimeLlDown.sum{it.sendTimes})
			print ','
			print sendTimeLlDown.grep{it.sec > 7}.sum{it.sendTimes}
			print ','
		}else{
			print '??,??,??,'
		}

		def sendTimeLlUp = sendTimeLl.grep{'up' == it.type}
		if(sendTimeLlUp){
			print sendTimeLlUp.sum{it.sec * it.sendTimes} / sendTimeLlUp.sum{it.sendTimes}
			print ','
			print sendTimeLlUp.grep{it.sec > 3 * 60}.sum{it.sendTimes} ?: 0
			print ','
		}else{
			print '??,??,'
		}
	}
	println ''
}

def parseStat = {lines ->
	lines.grep{it.contains('上传开始')}.grep{
		def arr = it.split(pat)
		arr[4] != '1.0'
	}.each{
		println it
	}
}

for(version in versions){
	for(dat in datRange){
		String datStr = dat.format(format)
		println datStr + ',' + version.padRight(20)
		List lines = getLinesTarget(datStr, version)
		printStat(lines, version)
	}
}

 

下面一段是根据table ddl(oracle)生成一些项目框架需要的文件(ibatis之类的,abator等工具太不局限了,自己写想怎么生成就怎么生成,顺便推荐大家用用国人的smarty4j,很8错)

 

import xx.Tpl

String dir = './'
String tpl_dir = dir + 'tpl/'

String output_dir = dir + 'output/'
String scriptfile = 'dbscript.sql'
String ns = 'quotation'

File f = new File(dir, scriptfile)

final String begin = 'create table'
final String end = ');'

// 把分析出的表和字段信息保存到这个List中
List dto_ll = []

// 根据ORACLE字段类型对应Java类型
def get_type = {str ->
	if(str.contains('NUMBER'))
		return 'BigDecimal'
	switch (str) {
	    case ~/CHAR/:
	        return 'String'
	    case ~/DATE/:
	        return 'Date'
	    case ~/NUMBER/:
	        return 'BigDecimal'
	    default:
	        return 'String'
	}
}

// 大小写转换到驼峰格式
def get_name = {str ->
	String r = str.toLowerCase().split('_').collect{it.capitalize()}.join('')
	return r[0].toLowerCase() + r[1..-1]
}

// 设置表主键
def add_table_pk = {table, cols ->
	for(item in dto_ll){
		if(item.name.equalsIgnoreCase(table)){
			cols.split(/,/).collect{it.trim()}.each{
				for(col in item.cols){
					if(col.src_name.equalsIgnoreCase(it))
						col.is_pk = true
				}
			}
		}
	}
}

// 添加表注释
def add_table_comment = {table, comment ->
	for(item in dto_ll){
		if(item.name.equalsIgnoreCase(table)){
			item.comment = comment.replaceAll(/\r\n/, ' ')
		}
	}
}

// 添加表字段注释
def add_comment = {table, col, comment ->
	for(item in dto_ll){
		if(item.name.equalsIgnoreCase(table)){
			for(it in item.cols){
				if(it.name == get_name(col)){
					it.comment = comment.replaceAll(/\r\n/, ' ')
				}
			}
		}
	}
}

// 分析表和字段
def parse = { str ->
	def mat = str =~ /(?s)create table ([^\(]+) +\((.+)\);/
	if(!mat)
		return

	String table_name = mat[0][1].toLowerCase().trim()
	String columns = mat[0][2]

	Map item = [name: table_name, 
		clazz: get_name(table_name).capitalize(), cols : []]
	columns.split(',').each{
		def arr = it.split(/\s+/)
		if(arr.size() > 1){
			item.cols << [src_name: arr[0], name: get_name(arr[0]), type: get_type(arr[1])]
		}
	}
	dto_ll << item
}

// 每一行遍历SQL文件,先分析表和字段
StringBuffer buffer = new StringBuffer()
boolean is_begin = false
boolean is_end = true
f.eachLine{line ->
	line = line.trim()
	if(line){
		line = line.replace(/\s+/, ' ')
		if(is_end && line.startsWith(begin)){
			is_begin = true
			is_end = false
		}
		if(is_begin && line.endsWith(end)){
			buffer << line

			is_end = true
			is_begin = false

			parse(buffer.toString())
			buffer.delete(0, buffer.size())
		}

		if(is_begin && !is_end)
			buffer << line
	}
}

// 分析注释(字段)
def mat = f.text =~ /(?s)comment on column ([^;]+) is([^;]+);/
mat.each{
	String table_col = it[1].trim()
	String comment = it[2].replaceAll(/\'/, '').trim()
	
	def arr = it[1].split(/\./)
	String table = arr[0]
	String col = arr[1]

	add_comment(table, col, comment)
}
// 分析注释(表)
def mat2 = f.text =~ /(?s)comment on table ([^;]+) is([^;]+);/
mat2.each{
	String table = it[1].trim()
	String comment = it[2].replaceAll(/\'/, '').trim()
	
	add_table_comment(table, comment)
}

// 分析主外健
def mat3 = f.text =~ /(?s)alter table ([^ ]+)[^;]+primary key \(([^\)]+)\)/
mat3.each{
	String table = it[1].trim()
	String primary_key_cols = it[2].trim()

	add_table_pk(table, primary_key_cols)
}

// 现在已经获取到DDL的信息
// 先创建必要的文件夹
def ant = new AntBuilder()
ant.mkdir dir : output_dir
ant.mkdir dir : output_dir + 'dto'
ant.mkdir dir : output_dir + 'sql'
ant.mkdir dir : output_dir + 'xml'
ant.mkdir dir : output_dir + 'dao'
ant.mkdir dir : output_dir + 'daoImpl'
ant.mkdir dir : output_dir + 'service'
ant.mkdir dir : output_dir + 'serviceImpl'
ant.mkdir dir : output_dir + 'action'
ant.mkdir dir : output_dir + 'test'
ant.mkdir dir : output_dir + 'mock'

//dto_ll.each{
//	println it
//}

final String pkg = 'com.***.' + ns
Tpl.init(tpl_dir, 'gbk')

if(args){
	if(args[0] == 'add'){
		// 生成insert语句
		if(args.size() != 2){
			println '请输入表名!'
		}else{
			String table = args[1]
			for(item in dto_ll){
				if(item.name.equalsIgnoreCase(table)){
					String cols_str = item.cols*.src_name.join(', ')
					String cols_str2 = item.cols*.name.collect{"#" + it + "#"}.join(', ')
					println "insert into ${item.name} (${cols_str}) values (${cols_str2})"
					break
				}
			}
		}
	}else if(args[0] == 'update'){
		// 生成update语句
		if(args.size() != 2){
			println '请输入表名!'
		}else{
			String table = args[1]
			for(item in dto_ll){
				if(item.name.equalsIgnoreCase(table)){
					String cols_str = item.cols.collect{it.src_name + " = #" + it.name + "#"}.join(', ')
					println "update ${item.name} set ${cols_str} where ***"
					break
				}
			}
		}
	}else if(args[0] == 'mock'){
		// 生成dto mock对象
		def out = new FileWriter(new File(new File(output_dir + 'mock'), 
			'DTOMock.java'))
		int half = dto_ll.size() / 2 as int
		Tpl.out([pkg: pkg, clazz: 'Mock', ll: dto_ll[0..half]], 'Mock.java', out)
		def out2 = new FileWriter(new File(new File(output_dir + 'mock'), 
			'DTOMock2.java'))
		Tpl.out([pkg: pkg, clazz: 'Mock2', ll: dto_ll[half + 1..-1]], 'Mock.java', out2)

		println 'Done DTO Mock'
	}else if(args[0] == 'deploy'){
		final String to_dir = 'D:/CCShare/epcis_ahs_dev3.0.0/epcis_ahs/ahs_j2ee/src/'
		String pkg_dir = pkg.replaceAll(/\./, '/')

		// Copy Java
		['/dto' : output_dir + 'dto', 
			'/integration/dao' : output_dir + 'dao', 
			'/integration/dao/ibatis' : output_dir + 'daoImpl', 
			'/biz/service' : output_dir + 'service', 
			'/biz/service/impl' : output_dir + 'serviceImpl', 
			].each{k, v ->
			String dir_to = to_dir + 'java/' + pkg_dir + k
			ant.copy todir : dir_to, {
				fileset dir : v
			}
		}

		// Copy Sql
		// Copy Bean Xml
		ant.copy todir : to_dir + 'config/biz', {
			fileset dir : output_dir + 'sql'
			fileset dir : output_dir + 'xml'
		}		
		println 'Done Deploy'
	}else if(args[0] == 'deploy_clear'){
		final String to_dir = 'D:/CCShare/epcis_ahs_dev3.0.0/epcis_ahs/ahs_j2ee/src/'
		String pkg_dir = pkg.replaceAll(/\./, '/')

		// Delete Java
		['/dto' : output_dir + 'dto', 
			'/integration/dao' : output_dir + 'dao', 
			'/integration/dao/ibatis' : output_dir + 'daoImpl', 
			'/biz/service' : output_dir + 'service', 
			'/biz/service/impl' : output_dir + 'serviceImpl', 
			].each{k, v ->
			String dir_to = to_dir + 'java/' + pkg_dir + k
			ant.delete dir : dir_to
		}

		println 'Clear Deploy'
	}
}else{
	// -- 输出生成DTO Java文件
	// 父类
	final String parent_clazz = 'BaseDTO'
	// 父类的包名
	final String parent_clazz_pkg = 'com.xxx.dto'
	def params = [pkg: pkg]
	params.parent_clazz = parent_clazz
	params.parent_clazz_pkg = parent_clazz_pkg
	dto_ll.each{
		String clazz = get_name(it.name).capitalize()
		params.clazz = clazz
		params.cols = it.cols
		params.has_date = it.cols.any{col -> col.type == 'Date'}
		params.has_bigdecimal = it.cols.any{col -> col.type == 'BigDecimal'}
		params.comment = it.comment

		def out = new FileWriter(new File(new File(output_dir + 'dto'), 
			clazz + 'DTO.java'))
		Tpl.out(params, 'Dto.java', out)

		println 'Done DTO For ' + clazz
	}

	// -- 输出生成Sql Mapping文件
	def params_ll = []
	dto_ll.each{item ->
		def one = [:]
		
		String clazz = get_name(item.name)
		one.clazz = clazz.capitalize()
		one.clazz2 = clazz
		one.comment = item.comment
		one.pk_col = item.cols.grep{it.is_pk}*.name.join(',')

		String cols_str = item.cols*.src_name.join(', ')
		String cols_str2 = item.cols*.name.collect{"#" + it + "#"}.join(', ')
		one.insert_sql = "insert into ${item.name} (${cols_str}) values (${cols_str2})"

		String cols_str3 = item.cols.grep{!it.is_pk}.collect{it.src_name + " = #" + it.name + "#"}.join(', ')
		String cols_str4 = item.cols.grep{it.is_pk}.collect{it.src_name + " = #" + it.name + "#"}.join(' and ')
		one.update_sql = "update ${item.name} set ${cols_str3} where ${cols_str4}"
		String cols_str44 = item.cols.grep{it.is_pk}.collect{it.src_name + " = #value#"}.join(' and ')
		one.delete_sql = "delete from ${item.name} where ${cols_str44}"

		String cols_str5 = item.cols.collect{it.src_name + " " + it.name}.join(', ')
		one.select_sql = "select ${cols_str5} from ${item.name} where 1 = 1 and ${cols_str4}"

		params_ll << one
	}
	def out = new FileWriter(new File(new File(output_dir + 'sql'), "sqlmap-mapping-${ns}.xml"))
	Tpl.out([namespace: ns.capitalize(), pkg: pkg, ll: params_ll], 
		'sql-mapping.xml', out)
	println 'Done Sql'

	// -- 输出dao/serivce
	params_ll.each{
		def params_sub = [pkg: pkg] + it
		def out1 = new FileWriter(new File(new File(output_dir + 'dao'), it.clazz + 'DAO.java'))
		Tpl.out(params_sub, 'IDao.java', out1)

		def out2 = new FileWriter(new File(new File(output_dir + 'daoImpl'), it.clazz + 'IbatisDAO.java'))
		Tpl.out(params_sub, 'Dao.java', out2)
		println 'Done DAO For ' + it.clazz

		def out3 = new FileWriter(new File(new File(output_dir + 'service'), it.clazz + 'Service.java'))
		Tpl.out(params_sub, 'IService.java', out3)
		def out4 = new FileWriter(new File(new File(output_dir + 'serviceImpl'), it.clazz + 'ServiceImpl.java'))
		Tpl.out(params_sub, 'Service.java', out4)
		println 'Done Service For ' + it.clazz
	}

	// -- 输出bean定义
	def out2 = new FileWriter(new File(new File(output_dir + 'xml'), "biz-context-${ns}.xml"))
	Tpl.out([namespace: ns.capitalize(), pkg: pkg, ll: params_ll], 
		'bean.xml', out2)
	println 'Done Bean'

//	ant.zip basedir : dir, destfile : dir + '../my.zip'
}
 

4. 一些算法和无聊写的小程序

模拟下双色球中奖的概率

 

def range = 1..33

int len = 7
List his = [
	[num: 10000, result: [3,5,16,18,23,24,15]], 
]

def rand = new Random()

def play = {
	int cc = 0
	List ll = []
	while(1){
		int one = rand.nextInt(range.size()) + 1
		if(one in ll){
		}else{
			ll << one
		}

		if(ll.size() == len && his.any{it.result == ll}){
			def target = his.find{it.result == ll}

			println cc
			println target.num
			println cc / target.num
			println target

			cc = 0
			ll.removeAll()

			break
		}

		if(ll.size() > len){
			ll.removeAll()
		}

		cc++
	}
}

play()

 

附件是一个简单的数字图像识别的程序——很简单的笔画匹配思路,很弱智的,大家也可以看看

 

 

这些是我零零散散找到的最近写过的groovy脚本——很多只是用到了简单的groovy语言的语法和api,不过很有意思而且确实能给自己带来工作的方便,喜欢groovy的童鞋们,一起继续支持啦

 

 

还有就是建议不要使用eclipse和groovy的插件——不给力的,找个简单的文本编辑器,vim/notepad++/editplus之类的,弄个宏运行bat,更快捷些

你可能感兴趣的:(groovy)