敏捷开发-基于JAVA POI 使用基础Excel解析
来源:互联网 发布:ec20模块linux驱动 编辑:程序博客网 时间:2024/06/05 21:59
- Excel
- 前提
- 一行一行形式的Excel
- 数据
- 分析
- 下载代码示例
- 简介的使用
Excel
前提
- 了解POI解析
(可粗略查找下了解如何基本解析) : 本文仅针对部分类型的Excel格式解析, 代码进行优化。
1. 一行一行形式的Excel
数据:
分析:
1.
问题: 如何对每行cell 简洁的获取到自己想要的数据。
方案: 实现CellReader 基于POI的Row 的 数据读取器
public class POIExcelCellReader { public POIExcelCellReader(Row row) public Cell next() throws IOException public String nextString() throws IOException public Integer nextInt() throws IOException public Date nextDate() throws IOException }
2.
问题: 统一解析接口
方案: 使用模板模式 对数据预先设置好解析策略 抽象每行的具体解析
public abstract class POIExcelRowParser <R> extends POIExcelParser { public List<R> parse() throws ExcelParseException //每个模板各自实现解析 protected abstract boolean parseRow(List<R> entrys, int index, POIExcelCellReader cellReader) throws ExcelParseException, IOException ; protected boolean parseHeader(Iterator<Row> iterator) protected void end()}
下载代码示例:
Demo下载地址: 。。。
简介的使用:
//1.Modelclass User { private String name; private String gender; private String age; private Date birth; private String phone; private String remark;}//2.解析器public class UserExcelParser extends POIExcelRowParser<User>{ @Override protected boolean parseRow(List<User> entrys, int index, POIExcelCellReader cellReader) throws ExcelParseException, IOException { //数据读取 String name = cellReader.nextString(); String phone = cellReader.nextString(); Integer age = cellReader.nextInt(); Date date = cellReader.nextDate(); String gender = cellReader.nextString(); String remark = cellReader.nextString(); //数据检查// if (!PhoneUtils.isPhone(phone)) {// throw new ExcelParseException(index, "号码格式错误");// }// 联合数据库检查// //数据整合 添加到entrys User entry = new User(); entry.setPhone(phone); entrys.add(entry); return true; }}
try { is = new FileInputStream(excel); userExcelParser.load03Workbook(is); users= userExcelParser.parse(); 打印("导入完成,数量:" + users.size());} catch (ExcelParseException e) { 打印("导入错误 : " + e.getMessage());} finally { if ( is!= null) { is.close(); }}
0 0
- 敏捷开发-基于JAVA POI 使用基础Excel解析
- Java使用poi解析Excel
- java基础入门-poi解析excel
- java使用poi实现excel解析
- java使用poi解析Excel文件
- 使用poi解析Excel
- 使用poi解析Excel
- 使用poi解析Excel
- 使用poi解析Excel
- 使用poi解析Excel
- 使用poi解析Excel
- 使用POI解析Excel
- java poi 解析excel
- java POI解析Excel
- java基于poi处理excel
- Java中使用Apache POI使用解析excel文件
- 使用POI解析excel getlastnum()
- 简单使用poi解析excel
- iOS之错误总结收集
- android中程序的执行顺序
- 第8周 项目4—字符串加密
- SpringMVC学习系列-后记 解决GET请求时中文乱码的问题
- 守卫农场阿波罗,大富翁
- 敏捷开发-基于JAVA POI 使用基础Excel解析
- Newtonsoft.Json(Json.Net)学习笔记
- 目录COPY
- 统计知识补充:方差,协方差,相关系数。
- TCP实现P2P通信、TCP穿越NAT的方法、TCP打洞
- swift tablevieCell自适应高度
- 队列数组
- 项目三——负数把正数赶出队列
- shiro中的缓存的配置与使用