读取excel,利用java反射组装实体集合
2015-12-21 10:58
471 查看
//因为java的反射,所以对文件名的要求为实体类的类名,excel第一行为实体类的属性名
private static List<Object> exportListFromExcel(Workbook workbook,
int sheetNum, String fileName) throws ClassNotFoundException,
NoSuchMethodException, SecurityException, IllegalAccessException,
IllegalArgumentException, InvocationTargetException,
InstantiationException {
Sheet sheet = workbook.getSheetAt(sheetNum);//需要解析的当前sheet
Class<?> clazz = Class.forName("com.sujiu.hwmall.model." + fileName);// java反射出来的实体类
List<Method> methods = new ArrayList<Method>();// 用于存放反射出来的set方法
// 解析公式结果
FormulaEvaluator evaluator = workbook.getCreationHelper()
.createFormulaEvaluator();
List<Object> list = new ArrayList<Object>();
int minRowIx = sheet.getFirstRowNum();
int maxRowIx = sheet.getLastRowNum();
for (int rowIx = minRowIx; rowIx <= maxRowIx; rowIx++) {
Object obj = clazz.newInstance();
Row row = sheet.getRow(rowIx);
short minColIx = row.getFirstCellNum();
short maxColIx = row.getLastCellNum();
for (short colIx = minColIx; colIx <= maxColIx; colIx++) {
Cell cell = row.getCell(new Integer(colIx));
CellValue cellValue = evaluator.evaluate(cell);
if (cellValue == null) {
continue;
}
if (cellValue.getCellType() == Cell.CELL_TYPE_NUMERIC) {// 数字类型,日期类型
if (DateUtil.isCellDateFormatted(cell)) {
Date field = cell.getDateCellValue();
if (rowIx == minRowIx) {// 第一行为 方法名行
String methodName = "set"
+ cellValue.getStringValue();
Method method = clazz.getDeclaredMethod(methodName,
Date.class);
methods.add(colIx, method);
} else {// 赋值操作
methods.get(colIx).invoke(obj, field);
}
} else {
Double field = cellValue.getNumberValue();
if (rowIx == minRowIx) {// 第一行为 方法名行
String methodName = "set"
+ cellValue.getStringValue();
Method method = clazz.getDeclaredMethod(methodName,
Double.class);
methods.add(colIx, method);
} else {// 赋值操作
methods.get(colIx).invoke(obj, field);
}
}
} else if (cellValue.getCellType() == Cell.CELL_TYPE_STRING) {// string类型
String field = cellValue.getStringValue();
if (rowIx == minRowIx) {// 第一行为 方法名行
String methodName = "set" + cellValue.getStringValue();
Method method = clazz.getDeclaredMethod(methodName,
String.class);
methods.add(colIx, method);
} else {// 赋值操作
methods.get(colIx).invoke(obj, field);
}
}
}
if (rowIx != minRowIx) {//不将第一行数据加载到list中去
list.add(obj);
}
}
return list;
}
private static List<Object> exportListFromExcel(Workbook workbook,
int sheetNum, String fileName) throws ClassNotFoundException,
NoSuchMethodException, SecurityException, IllegalAccessException,
IllegalArgumentException, InvocationTargetException,
InstantiationException {
Sheet sheet = workbook.getSheetAt(sheetNum);//需要解析的当前sheet
Class<?> clazz = Class.forName("com.sujiu.hwmall.model." + fileName);// java反射出来的实体类
List<Method> methods = new ArrayList<Method>();// 用于存放反射出来的set方法
// 解析公式结果
FormulaEvaluator evaluator = workbook.getCreationHelper()
.createFormulaEvaluator();
List<Object> list = new ArrayList<Object>();
int minRowIx = sheet.getFirstRowNum();
int maxRowIx = sheet.getLastRowNum();
for (int rowIx = minRowIx; rowIx <= maxRowIx; rowIx++) {
Object obj = clazz.newInstance();
Row row = sheet.getRow(rowIx);
short minColIx = row.getFirstCellNum();
short maxColIx = row.getLastCellNum();
for (short colIx = minColIx; colIx <= maxColIx; colIx++) {
Cell cell = row.getCell(new Integer(colIx));
CellValue cellValue = evaluator.evaluate(cell);
if (cellValue == null) {
continue;
}
if (cellValue.getCellType() == Cell.CELL_TYPE_NUMERIC) {// 数字类型,日期类型
if (DateUtil.isCellDateFormatted(cell)) {
Date field = cell.getDateCellValue();
if (rowIx == minRowIx) {// 第一行为 方法名行
String methodName = "set"
+ cellValue.getStringValue();
Method method = clazz.getDeclaredMethod(methodName,
Date.class);
methods.add(colIx, method);
} else {// 赋值操作
methods.get(colIx).invoke(obj, field);
}
} else {
Double field = cellValue.getNumberValue();
if (rowIx == minRowIx) {// 第一行为 方法名行
String methodName = "set"
+ cellValue.getStringValue();
Method method = clazz.getDeclaredMethod(methodName,
Double.class);
methods.add(colIx, method);
} else {// 赋值操作
methods.get(colIx).invoke(obj, field);
}
}
} else if (cellValue.getCellType() == Cell.CELL_TYPE_STRING) {// string类型
String field = cellValue.getStringValue();
if (rowIx == minRowIx) {// 第一行为 方法名行
String methodName = "set" + cellValue.getStringValue();
Method method = clazz.getDeclaredMethod(methodName,
String.class);
methods.add(colIx, method);
} else {// 赋值操作
methods.get(colIx).invoke(obj, field);
}
}
}
if (rowIx != minRowIx) {//不将第一行数据加载到list中去
list.add(obj);
}
}
return list;
}
相关文章推荐
- 使用Python生成Excel格式的图片
- Excel 曝出 Power Query 安全漏洞,1.2 亿用户易受远程 DDE 攻击
- VBA将excel数据表生成JSON文件
- excel vba 限制工作表的滚动区域代码
- excel vba 高亮显示当前行代码
- SQL 导入导出Excel数据的语句
- 文本、Excel、Access数据导入SQL Server2000的方法
- C#导出数据到Excel文件的方法
- Vbscript生成Excel报表的常用操作总结
- C#实现导入CSV文件到Excel工作簿的方法
- C#基于NPOI生成具有精确列宽行高的Excel文件的方法
- 总提示[Microsoft][ODBC Excel Driver] 数值字段溢出官方解决方法
- C#将Sql数据保存到Excel文件中的方法
- VC6.0实现读取Excel数据的方法
- C#定制Excel界面并实现与数据库交互的方法
- 把excel表格里的数据导入sql数据库的两种方法
- access dbase excel foxpro 数据库浏览器V3.1版 下载
- C#实现把txt文本数据快速读取到excel中
- C#自定义导出数据到Excel的类实例
- 使用PHPExcel操作Excel用法实例分析