自动生成bean

一个很简单的功能,用来自动生成bean代码


CreateBean.java
代码:

package com.auto.util;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.RandomAccessFile;
import java.io.UnsupportedEncodingException;
import java.util.ArrayList;

public class CreateBean {
	public CreateBean() {

	}

	public ArrayList<String> readFile(String filename) {
		ArrayList<String> line = new ArrayList<String>();
		try {
			File f = new File(filename);
			RandomAccessFile rf = new RandomAccessFile(f, "r");
			String temp;
			while (rf.read() != -1) {
				rf.seek(rf.getFilePointer() - 1);
				temp = new String(rf.readLine().getBytes("8859_1"));
				if(temp.trim().length()>1){
					line.add(temp);
				}
			}
			rf.close();
		} catch (NullPointerException e) {
			e.printStackTrace();
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (UnsupportedEncodingException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}
		
		return line;

	}

	public void createBean(String filename, ArrayList<String> elements) {
		String reqfilename="Req_"+ filename+".java";
		String path = System.getProperty("user.dir")
				+ "\\src\\com\\business\\reqbean\\";
		File f = new File(path +reqfilename);
		try {
			f.createNewFile();
			StringBuffer beancode = new StringBuffer();
			beancode.append("package com.business.reqbean;");
			beancode.append("\r\n");
			beancode.append("/**CreateBean自动生成代码*/");
			beancode.append("\r\n");
			beancode.append("public class Req_"+filename+" {");
			beancode.append("\r\n    ");
			for (String ts : elements) {
				String[] ns = ts.split("	");
				beancode.append("/**"+ns[2]+"*/");
				beancode.append("\r\n    ");
				if(ns.length>4){
					beancode.append("/**"+ns[4]+"*/");
					beancode.append("\r\n    ");
				}
				beancode.append("private "+ns[1]+" "+ns[0]+";");
				beancode.append("\r\n    ");
				beancode.append("public "+ns[1]+" get"+chargeMethod(ns[0])+"(){");
				beancode.append("\r\n        ");
				beancode.append("return "+ns[0]+";");
				beancode.append("\r\n    ");
				beancode.append("}");
				beancode.append("\r\n    ");
				beancode.append("public void"+" set"+chargeMethod(ns[0])+"("+ns[1]+" "+ns[0]+"){");
				beancode.append("\r\n        ");
				beancode.append("this."+ns[0]+" = "+ns[0]+";");
				beancode.append("\r\n    ");
				beancode.append("}");
				beancode.append("\r\n    ");
			}
			beancode.append("\r\n");
			beancode.append("}");

			RandomAccessFile rf = new RandomAccessFile(f, "rw");
			rf.write(beancode.toString().getBytes("UTF-8"));
			rf.close();
		} catch (FileNotFoundException e) {
			e.printStackTrace();
		} catch (IOException e) {
			e.printStackTrace();
		}

	}
	private String chargeMethod(String f){
		return f.substring(0, 1).toUpperCase()+f.substring(1);
	}

	public static void main(String args[]) {
		CreateBean cb = new CreateBean();
		ArrayList<String> elements = cb.readFile(System.getProperty("user.dir")
				+ "\\beanDepict\\interfacename");
		cb.createBean("interfacename", elements);

	}
}


使用的时候准备一个文本文件 interfacename
内容如下
phoneNum java.lang.String手机号码 必须目前支持移动和联通
放在beanDepict目录下
运行后生成bean  Req_interfacename.java


package com.business.reqbean;
/**CreateBean自动生成代码*/
public class Req_interfacename {
    /**手机号码*/
    /**目前支持移动和联通*/
    private java.lang.String phoneNum;
    public java.lang.String getPhoneNum(){
        return phoneNum;
    }
    public void setPhoneNum(java.lang.String phoneNum){
        this.phoneNum = phoneNum;
    }
    
}




转载于:https://www.cnblogs.com/zymaxs/p/4292929.html

博客地址:http://blog.csdn.net/vipbooks 一直以来把数据库的表转换成Entity或DTO都是一件让人头痛的事情,既浪费时间又很繁琐,看着几十上百个表的几百上千个字段,真是一件让人很头痛的事情。 我们也想过很多办法解决这个问题,包括用MyEclipse连接数据库生成JavaBean,但多多少少还是会有一些不尽人意的地方,包括表和表字段的comment总是无法生成,而且还会生成很多无用的注释代码,让代码看起来一点都不干净,配置非常繁琐等等问题。 于是一怒之下,自己动手丰衣足食,就自己用Swing写了一个通过数据库的表生成JavaBean的工具,支持MySQL、Oracle、SQLServce、PostgreSQL,完美支持JPA注解,可以同时生成Entity和DTO,可以自动去除表前缀,并支持去除多个前缀,支持精确指定只生成哪几个表的Bean,也支持模糊查找生成哪几个表的Bean,现在不但成员变量上能生成备注了,而且在Getter和Setter上也能有备注了! 更重要的是所有的配置都能被保存到本地,只要配置过一次,下次使用只要点一下生成JavaBean,下一秒就能拿到你想要的JavaBean了,完全实现秒生成。并且集成各种实用工具,使得工作效率瞬间爆棚,生产力瞬间爆表! 第12版更新震撼发布,此次版本更新如下: 1、新增参数配置管理功能,可以为不同的项目配置不同的参数。 2、新增快速新增参数配置功能,快速为项目添加参数配置。 3、新增选择实体注解功能,生成实体的时候自动为实体添加额外的注解。 4、弹出对话框界面大小调整。 5、新增数据源添加默认设置。 6、精确匹配在点更多时,已选中的表会在弹出的列表中被勾选中。 7、修复模糊匹配找不到表的Bug。 8、其他一些小Bug的修改和代码优化调整。
博客地址:http://blog.csdn.net/vipbooks 一直以来根据数据库表结构自动生成JavaBean、自动生成MyBaits的Mapper映射配置文件、自动生成数据库设计文档都是一件让人很头痛的事情,既浪费时间又很繁琐,看着几十上百个表的成千上万个字段,真是一件让人痛苦的事情。 我们也想过很多办法解决这个问题,包括用MyEclipse连接数据库生成JavaBean,但多多少少还是会有一些不尽人意的地方,包括表和表字段的comment总是无法生成,而且还会生成很多无用的注释代码,让代码看起来一点都不干净,配置非常繁琐等等问题。 于是一怒之下,自己动手丰衣足食,于是就自己用Swing写了一个基于数据库的自动化生成工具,支持MySQL、Oracle、SQLServce、PostgreSQL四种数据库,支持Window、Linux、MacBook等多个作系统,完美支持JPA注解,可以同时生成Entity和DTO等,可以自动去除表前缀,支持单个和批量生成JavaBean,现在不但成员变量上能生成备注了,而且在Getter和Setter上也能有注释了。更重要的是还能自动生成数据库设计文档和MyBaits的Mapper映射配置文件,如果有多个数据源还能批量生成,使用非常方便。 所有的配置都保存在本地,只要配置过一次,下次使用的时候完全可以秒生成JavaBean、MyBaits的Mapper映射配置文件和数据库设计文档,并且还集成各种实用工具,使得工作效率瞬间爆棚,生产力瞬间爆表! TableGo v5.8.0版更新震撼发布,此次版本更新如下: 1、新增自定义文件功能,可以自己编写模板生成任意代码的文件。 2、新增数据源配置自动生成功能,项目分库分表不用愁,一次搞定所有数据源。 3、公共参数界面新增表别名和是否目录直通的配置。 4、生成Bean界面新增是否生成字段注释和重写equals,hashCode,toString方法的配置。 5、MyBatis配置界面新增根据所有字段条件查询数据的选项。 6、新增TableGo使用说明书。 7、更新数据库驱动版本,新版的驱动可能不支持JDK8以下的版本。 8、修复了大量的Bug并进行了一些优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值