list<?>转换成 对应的 class
项目中用到的,list转换成bean。因为查询出来的数据用list 泛型接收,要返回 实体对象。所以需要对应转换。
主要用到的技术:反射。
上代码:
public static <T> List<T> toBean(List<?> list, Class<T> clz) {
int count = 0;
Field[] fields = clz.getDeclaredFields();
List<T> lst = new ArrayList();
String propertyName = "";
Object obj = null;
try {
for(int i = 0; i < list.size(); ++i) {
obj = clz.newInstance();
Object[] oo = (Object[])list.get(i);
Field[] var12 = fields;
int var11 = fields.length;
for(int var10 = 0; var10 < var11; ++var10) {
Field fd = var12[var10];
Type t = fd.getGenericType();
String className = t.toString().replace("class", "");
Class<?> type = Class.forName(className.trim());
propertyName = "set" + change(fd.getName());
Method mt = obj.getClass().getMethod(propertyName, new Class[]{type});
if(!"java.lang.String".equals(className.trim())) {
if("java.lang.Integer".equals(className.trim())) {
mt.invoke(obj, new Object[]{Integer.valueOf(Integer.parseInt(oo[count] == null?"-1":oo[count].toString()))});
} else if("java.lang.Long".equals(className.trim())) {
mt.invoke(obj, new Object[]{Long.valueOf(Long.parseLong(oo[count] == null?"-1":oo[count].toString()))});
} else {
Clob clobs;
if("java.sql.Date".equals(className.trim())) {
Date date = (Date)oo[count];
if(!"".equals(date) && date != null) {
java.sql.Date sd = new java.sql.Date(date.getTime());
mt.invoke(obj, new Object[]{sd});
} else {
clobs = null;
mt.invoke(obj, new Object[]{clobs});
}
} else if("oracle.sql.CLOB".equals(className.trim())) {
if(oo[count] == null) {
mt.invoke(obj, new Object[1]);
} else {
SerializableClobProxy sc = (SerializableClobProxy)Proxy.getInvocationHandler(oo[count]);
clobs = sc.getWrappedClob();
CLOB clob = (CLOB)clobs;
mt.invoke(obj, new Object[]{clob});
}
} else {
mt.invoke(obj, new Object[]{oo[count]});
}
}
} else {
String s = "" + oo[count];
if(s == null || "null".equals(s)) {
s = "";
}
mt.invoke(obj, new Object[]{s});
}
++count;
}
count = 0;
lst.add((T)obj);
}
} catch (SecurityException var20) {
logger.error(var20.getMessage());
} catch (IllegalArgumentException var21) {
logger.error(var21.getMessage());
} catch (InstantiationException var22) {
logger.error(var22.getMessage());
} catch (IllegalAccessException var23) {
logger.error(var23.getMessage());
} catch (ClassNotFoundException var24) {
var24.printStackTrace();
logger.error(var24.getMessage());
} catch (NoSuchMethodException var25) {
logger.error(var25.getMessage());
} catch (InvocationTargetException var26) {
logger.error(var26.getMessage());
}
return lst;
}
list<?>转换成 对应的 class的更多相关文章
- DataTable 转换成 Json的3种方法
在web开发中,我们可能会有这样的需求,为了便于前台的JS的处理,我们需要将查询出的数据源格式比如:List<T>.DataTable转换为Json格式.特别在使用Extjs框架的时候,A ...
- 微信小程序中利用时间选择器和js无计算实现定时器(将字符串或秒数转换成倒计时)
转载注明出处 改成了一个单独的js文件,并修改代码增加了通用性,点击这里查看 今天写小程序,有一个需求就是用户选择时间,然后我这边就要开始倒计时. 因为小程序的限制,所以直接选用时间选择器作为选择定时 ...
- C#将Word转换成PDF方法总结(基于Office和WPS两种方案)
有时候,我们需要在线上预览word文档,当然我们可以用NPOI抽出Word中的文字和表格,然后显示到网页上面,但是这样会丢失掉Word中原有的格式和图片.一个比较好的办法就是将word转换成pdf,然 ...
- DataTable转换成IList<T>的简单实现
DataTable的无奈 很多时候,我们需要去操作DataTable.但DataTable的操作,实在是太不方便了.Linq?lambda表达式?统统没有... 特别是对现有结果集做进一步筛选,这样的 ...
- ASP.Net中实现上传过程中将文本文件转换成PDF的方法
iTextSharp是一个常用的PDF库,我们可以使用它来创建.修改PDF文件或对PDF文件进行一些其他额外的操作.本文讲述了如何在上传过程中将文本文件转换成PDF的方法. 基本工作 在开始之前,我们 ...
- asp.net dataTable转换成Json格式
/// <summary> /// dataTable转换成Json格式 /// </summary> /// <param name="dt"> ...
- [jquery]将当前时间转换成yyyymmdd格式
如题: function nowtime(){//将当前时间转换成yyyymmdd格式 var mydate = new Date(); var str = "" + mydate ...
- Gson将字符串转换成JsonObject和JsonArray
以下均利用Gson来处理: 1.将bean转换成Json字符串: public static String beanToJSONString(Object bean) { return new Gso ...
- JAVA将数字字符串强制转换成整型变量----求参数之和实验代码(附流程图)
一.设计思想 先将参数个数输出,并利用循环结果将参数逐个输出,再将字符串强制转化成整型,利用循环结构相加求和 二.程序流程图 三.源程序代码 package demo; public class Co ...
- pk8和x509.pem转换成keystore
转自:http://www.cnblogs.com/platte/p/3511814.html 一 在github上下载工具 https://github.com/getfatday/keytool- ...
随机推荐
- [Java.Web]从零开始布署 Tomcat
1. 下载 JRE 1.7 2. 下载 Tomcat 7.0.77,我使用的是红圈的压缩包版本,也可以使用绿圈的安装包版本[更省心] 3. 加入环境变量 JRE_HOME .CATALINA_HOME ...
- 【学步者日记】实现破碎效果 Fracturing & Destruction 插件使用
全文见原始链接:http://note.youdao.com/noteshare?id=ef5ef90b71da4e960e5bc0da4f3f17ec 下面是预览 示例工程链接:https://pa ...
- MySQL Connector/NET 使用小结(踩坑之路)
背景描述 根据项目的需要,需连接MySQL获取数据. 首先,先了解一下项目的情况: 之前的代码是C#编写的的, 运行时:.NETFramework3.5. 由于项目已经部署上线,因此不能升级运行时,这 ...
- 后台给GridView绑定数据时给每一行添加一个JS方法
--------JS function ReturnDictionaryValues(srcElement) { top.document.getElementById("_DialogFr ...
- 关于alter database open resetlogs及incarnation的一点理解
关于alter database open resetlogs及incarnation的一点理解 不完全恢复只能做一次吗? 采用rman的默认设置,对数据库进行了backup database备份,进 ...
- python学习笔记(九):操作数据库
我们在写代码的时候,经常会操作数据库,增删改查,数据库有很多类型,关系型数据库和非关系数据库,这里咱们介绍一下python怎么操作mysql.redis和mongodb. 一.python操作mysq ...
- Julia - 复合表达式
复合表达式是用一个表达式按照顺序对一系列子表达式求值,并返回最后一个子表达式的值 有两种方法:begin 块和 “;” 链 begin 块 begin 块的多行写法 julia> a = beg ...
- mac 上sed
mac上sed和liunx是不一样的,所以有些指令可能不通用,需要将mac上sed替换成gun的: Install Homebrew First, visit Homebrew homepage an ...
- Python实践练习:口令保管箱
缘由 做中学才是最好的方法,通过这些项目来加强自己的Python掌握程度. 所有练习目录地址 题目描述: 一个字典中存在着账户和密码,通过命令行参数直接执行,查看是否有这个账户. 若有,则复制账户的密 ...
- 读<分布式一致性原理>初识zookeeper
zookeeper是什么 zookeeper是一个典型的分布式数据一致性的解决方案,分布式应用程序可以基于它实现诸如:数据发布/订阅,负载均衡,命名服务,分布式协调/通知 ,集群管理,Master选举 ...