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堆外内存之七:JVM NativeMemoryTracking 分析堆外内存泄露
Native Memory Tracking (NMT) 是Hotspot VM用来分析VM内部内存使用情况的一个功能.我们可以利用jcmd(jdk自带)这个工具来访问NMT的数据. NMT介绍 工欲 ...
- 一、Jetty介绍
简介: Jetty 是一个用 Java 实现.开源.基于标准的,并且具有丰富功能的 Http 服务器和 Web 容器,可以免费的用于商业行为.Jetty 这个项目成立于 1995 年,现在已经有非常多 ...
- mysql 使用 informatin_schema tables 创建 shell commands
SELECT CONCAT("mysqldump -uroot -p ", TABLE_SCHEMA, " ", TABLE_NAME, " > ...
- python解析时间格式脚本
对于这种时间格式:發表於: 星期一 五月 28, 2012 6:59 am import re INPUT = "發表於: 星期一 五月 28, 2012 6:59 am 文章主題: 對&l ...
- document.getElementById/Name/TagName
document.getElementById 1.getElementById 作用:一般页面里ID是唯一的,用于准备定位一个元素 语法: document.getElementById(id) 参 ...
- Web页面工作流设计器
http://www.cnblogs.com/2018/archive/2011/11/22/2240259.html http://wenku.baidu.com/link?url=LSqlCiqi ...
- microtip Tooltip工具提示样式
最近开发项目,想增加滑动提示文字,类似img alt和i的title,但是效果都不是很理想,当然jq也有,但是用起来比较繁琐,使用不是特别方便 于是在github上看到了一个不错的库: https:/ ...
- redis的二种启动方式
.直接启动 进入redis根目录,执行命令: #加上‘&’号使redis以后台程序方式运行 1 ./redis-server & 2.通过指定配置文件启动 可以为redis服务启 ...
- MonkeyScript测试命令集合
MonkeyScript:(不支持截屏) 可以被Monkey识别的集合命令 可以完成重复固定的操作 MonkeyRunner(支持截屏操作) 提供一系列API,可以完成模拟事件和截屏操作 Mo ...
- Linux下编译、安装php
一.apache环境下php的安装步骤如下:[注意:编译安装php前,应先安装好apache,因为编译php时要用到apache的路径] 1. 在http://www.php.net/download ...