资源简介
Java操纵POI解析Excel表,根据表头将内容储存。通过实体类set、get方便其它方法引用
代码片段和文件信息
package com.cn.excel;
import java.io.File;
import java.lang.reflect.Method;
import java.util.ArrayList;
import java.util.List;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellType;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Row.MissingCellPolicy;
import org.apache.poi.ss.util.CellRangeAddress;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.usermodel.WorkbookFactory;
public class Test {
public static void main(String[] args) {
List testList = load(“src/main/resources/test.xlsx“ “工作表1“ TestPo.class);
for (int i = 0; i < testList.size(); i++) {
System.out.print(“【“ + testList.get(i).getNo() + “】“);
System.out.print(“【“ + testList.get(i).getName() + “】“);
System.out.print(“【“ + testList.get(i).getValue() + “】“);
System.out.println();
}
}
/**
* 解析Excel表
*
* @param excelPath
* 文件路径
* @param sheetName
* 工作表名
* @param clazz
* 实体类
* @return
*/
public static List load(String excelPath String sheetName Class clazz) {
List list = new ArrayList();
try {
// 创建workbook对象
Workbook workbook = WorkbookFactory.create(new File(excelPath));
// 获取表单sheetName
Sheet sheet = workbook.getSheet(sheetName);
// 获取第一行
Row titleRow = sheet.getRow(0);
// 获取最后一列列号(列数)
int lastCellNum = titleRow.getLastCellNum();
String[] fields = new String[lastCellNum];
// 循环处理每一列取出每一列的字段名保存到数组(处理表头)
for (int column = 0; column < lastCellNum; column++) {
Cell cell = titleRow.getCell(column MissingCellPolicy.CREATE_NULL_AS_BLANK);
cell.setCellType(CellType.STRING);
String title = cell.getStringCellValue();
title = title.substring(0 title.indexOf(“(“));
fields[column] = title;
}
// 获取最后一列行号
int lastRowIndex = sheet.getLastRowNum();
// 循环处理每一个数据行
for (int row = 0; row <= lastRowIndex; row++) {
T obj = clazz.newInstance();
// 拿到一个数据行
Row dataRow = sheet.getRow(row);
if (dataRow == null || isEmptyRow(dataRow)) {
continue;
}
// 拿到此数据行上的每一列
for (int column = 0; column < lastCellNum; column++) {
Cell cell = dataRow.getCell(column MissingCellPolicy.CREATE_NULL_AS_BLANK);
cell.setCellType(CellType.STRING);
String value = null;
// 获取单元格的值
value = getCellValue(cell);
if (isMergedRegion(sheet row column)) {
value = getMergedRegionValue(sheet row column);
}
// 获取要反射的方法
String methodName = “set“ + fields[column];
// 获取要反射的方法对象
Method method = clazz.getMethod(methodName String.class);
// 完成反射调用
method.invoke(obj value);
}
list.add(obj);
}
} catch (Exception e) {
e.printStackTrace();
}
return list;
}
/**
* 判断指定的单元格是否是合并单元格
*
* @param sheet 表单
* @param row 行
* @param column 列
* @return
*/
public static boolean isMergedRegion(Sheet sheet int row int column
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
目录 0 2019-01-22 11:50 excelTest\
文件 6148 2019-01-22 11:50 excelTest\.DS_Store
目录 0 2019-01-22 11:50 __MACOSX\
目录 0 2019-01-22 11:50 __MACOSX\excelTest\
文件 120 2019-01-22 11:50 __MACOSX\excelTest\._.DS_Store
文件 550 2019-01-16 11:51 excelTest\pom.xm
文件 1395 2019-01-16 11:49 excelTest\.classpath
目录 0 2019-01-16 11:49 excelTest\.settings\
文件 238 2019-01-16 11:49 excelTest\.settings\org.eclipse.jdt.core.prefs
文件 86 2019-01-16 11:49 excelTest\.settings\org.eclipse.m2e.core.prefs
文件 538 2019-01-16 11:49 excelTest\.project
目录 0 2019-01-16 11:49 excelTest\src\
目录 0 2019-01-16 11:49 excelTest\src\test\
目录 0 2019-01-16 11:49 excelTest\src\test\resources\
目录 0 2019-01-16 11:49 excelTest\src\test\java\
目录 0 2019-01-16 11:49 excelTest\src\main\
目录 0 2019-01-22 11:47 excelTest\src\main\resources\
文件 21355 2019-01-22 11:47 excelTest\src\main\resources\test.xlsx
目录 0 2019-01-22 11:50 __MACOSX\excelTest\src\
目录 0 2019-01-22 11:50 __MACOSX\excelTest\src\main\
目录 0 2019-01-22 11:50 __MACOSX\excelTest\src\main\resources\
文件 188 2019-01-22 11:47 __MACOSX\excelTest\src\main\resources\._test.xlsx
目录 0 2019-01-16 11:50 excelTest\src\main\java\
目录 0 2019-01-16 11:50 excelTest\src\main\java\com\
目录 0 2019-01-16 11:50 excelTest\src\main\java\com\cn\
目录 0 2019-01-22 11:46 excelTest\src\main\java\com\cn\excel\
文件 5265 2019-01-22 11:46 excelTest\src\main\java\com\cn\excel\Test.java
文件 697 2019-01-16 16:48 excelTest\src\main\java\com\cn\excel\TestPo.java
相关资源
- java动态识别文件编码EncodingDetect.jav
- 五子棋 人机对弈 JAVA实现
- 五子棋 人机对弈 只有棋盘版本
- 微信java支付和登录api demo
- Java经典编程题汇总
- java在线预览需要的jar包
- 未来教育二级java激活码
- Java课程设计文档说明书商城项目
- 双人对战java贪吃蛇
- Java爬虫项目
- 坦克大战Java源码适合新手
- JavaDES通过秘钥加密解密Demo
- 基于java socket使用tcp udp进行简易控制
- JAVA网络程序设计动态温度曲线绘制
- Java动态编译Java代码,运行在内存中,
- javaweb登录页面
- Java深入微服务原理改造房产销售平台
- 基于Java的Oracle学生成绩管理系统
- 用java做一个计算器和科学计算器
- Jpcap.dll_64x_32x,及。jar包
- java录屏详细代码
- Java学习路径.pdf
- ftp安装 Java实现客户端
- 射击小球键控java小游戏
- Java+SQLServer学生成绩管理系统
- jtds 1.2.7.jar
- javax.servlet.jar包
- java开发详细设计文档模板
- java的学生管理系统+数据库
- webupload Java版轻松上传4个G文件
评论
共有 条评论