java jxl利用反射将数据库数据导入到Excel

import java.io.File;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;


import jxl.Workbook;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;


public class Book {


private List<Object> listfm;


public Book() {
listfm = new ArrayList<Object>();
}


/**
* @param list 查询所获得的结果集合
* @param path 导入的目标路径
*/


public void createBook(List<? extends Object> list, String path) {
if (list != null && list.size() != 0) {
Class<? extends Object> classes = list.get(0).getClass();// 获取实体类
String name = classes.getName();// 实体类全名
getListfm(classes);
WritableWorkbook wwb = null;
// 创建可写入的Excel工作簿
File file = new File(path);
try {
if (!file.exists()) {
file.createNewFile();
}
// 以file来创建一个Workbook
wwb = Workbook.createWorkbook(file);
// 创建工作表,表名通过类全名截取后转化为小写(cn.com.bean.DeptBean换成dept)
WritableSheet ws = wwb.createSheet(
name.substring(name.lastIndexOf('.') + 1,
name.lastIndexOf('B')).toLowerCase(), 0);
// 要插入到的Excel表格的行号,默认从0开始
for (int i = 0; i < listfm.size() / 2; i++) {
// 将属性字段加入到表头,0表示第一行,i表示对应的列
ws.addCell(new Label(i, 0, (String) listfm.get(2 * i)));
for (int j = 0; j < list.size(); j++) {
// 通过反射调用get方法获取字段对应的指添加到表中,i为列,j+1为对应的第几条记录
ws.addCell(new Label(i, j + 1, String
.valueOf(((Method) listfm.get(2 * i + 1))
.invoke(list.get(j), null))));
}
}
wwb.write();// 写入工作簿
wwb.close();// 关闭工作簿
} catch (Exception e) {
e.printStackTrace();
}
}
}


private void getListfm(Class<? extends Object> object) {
Method[] methods = object.getDeclaredMethods();// 获取类中声明的方法数组
for (Method method : methods) {
// 判定是否get方法
if (method.getName().startsWith("get")) {
// 截取掉方法名中的get并全部转化为小写就是对应的属性名
String fName = method.getName().substring(3).toLowerCase();
listfm.add(fName);// 存入属性名
listfm.add(method);// 存入get方法
}
}
}


}





  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值