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方法
}
}
}
}
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方法
}
}
}
}