java excel 模板_java对Excel模板的读取
java如何读取Excel简单模板
场景:对于经常需要导入Excel模板或数据来解析后加以应用的,使用频率非常之高,做了一个比较稳定的版本,体现在这些地方
工具:org.apache.poi
使用前必须了解这些:
1、要解析,那肯定先判断是不是Excel
2、xls后缀的Excel,是03版及以前的用HSSFWorkbook类
xlsx后缀的Excel,是07版及以后的用XSSFWorkbook解析
3、getWorkbook这个方法是我自己乱造各种Excel数据不断测试搜索修正得出的结果,其他的像简单的判断后缀xls还是xlsx来决定用HSSH还是XSSF是不保险的,比如你可能没遇过org.apache.poi.openxml4j.exceptions.InvalidFormatException这样的异常,当然这个异常仍然是因为Excel类型导致获取workbook时出错,然而我查到的结果是,Excel最底层是xml实现的,类型问题出在这儿,看异常的描述也可以稍微看出来openxml4j.exceptions
4 、可能出现空行,空的单元格,或者单元格值为空的情况,这些情况,在我的readExcel()方法里都考虑到了,为什么我不用迭代器,或者加强的for each循环?就是因为这些坑爹的空单元格或者空行啊,迭代器内部在取cell单元格对象时跳过这些空的对象,who knows why?我也不知道,反正我测试过,跳过去了,本来5个单元格,一个空的,结果就只得到4个数据,即使用cell.isEmpty()和cell!=null来判断,也没卵用,因为遍历的时候直接跳过去了,都没有判断的机会
5、取单元格数据,这个就比较简单了,判断单元格类型,根据类型做相应的处理取出来,但是我觉得我这个getCellValue()的方法应该有漏洞,先这么用着
下面上代码,简单描述下关键部位
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.io.PushbackInputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Map;
import java.util.List;
import org.apache.poi.POIXMLDocument;
import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
import org.apache.poi.openxml4j.opc.OPCPackage;
import org.apache.poi.poifs.filesystem.POIFSFileSystem;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.xmlbeans.impl.piccolo.io.FileFormatException;
/**
*yanbiao 2016.10.25
*/
public class ExcelUtil {
private static final String EXTENSION_XLS = "xls";
private static final String EXTENSION_XLSX = "xlsx";
/**
* 文件检查
*/
private void preReadCheck(String filePath) throws FileNotFoundException, FileFormatException {
File file = new File(filePath);
if (!file.exists()) {
throw new FileNotFoundException("导入的文件不存在:" + filePath);
}
if (!(filePath.endsWith(EXTENSION_XLS) || filePath.endsWith(EXTENSION_XLSX))) {
throw new FileFormatException("传入的文件不是excel");
}
}
/**
* 取得WorkBook对象
* xls:HSSFWorkbook,03版
* xlsx:XSSFWorkbook,07版
*/
private Workbook getWorkbook(String filePath) throws IOException, InvalidFormatException {
//直接判断后缀来返回相应的Workbook对象多数情况没问题,但是这个更保险,第3条已经说明
Workbook wb = null;
InputStream is = new FileInputStream(filePath);
if (!is.markSupported()) {
is = new PushbackInputStream(is, 8);
}
if (POIFSFileSystem.hasPOIFSHeader(is)) {
return new HSSFWorkbook(is);
}
if (POIXMLDocument.hasOOXMLHeader(is)) {
return new XSSFWorkbook(OPCPackage.open(is));
}
throw new IllegalArgumentException("您的excel版本目前不支持poi解析");
}
/**
* 读取excel文件内容
*/
public Map> readExcel(String filePath) throws FileNotFoundException, FileFormatException {
// 检查和获取workbook对象
this.preReadCheck(filePath);
Workbook wb = null;
Map> map = new HashMap>();
try {
wb = this.getWorkbook(filePath);
// 默认只读取第一个sheet
Sheet sheet = wb.getSheetAt(0);
int rowcount = sheet.getLastRowNum();//逻辑行,包括空行
int cellcount = sheet.getRow(0).getLastCellNum();//第一行(将来作为字段的行)有多少个单元格
for (int i=0;i
List list = new ArrayList();
Row row = sheet.getRow(i);
if(null!=row){
for (int j=0;j
list.add(getCellValue(row.getCell(j))); //这里也是用for循环,用Cell c:row这样的遍历,空单元格就被抛弃了
}
System.out.println("第"+(row.getRowNum()+1)+"行数据:"+list.toString());
map.put(row.getRowNum(), list);
}else{
for (int j=0;j
list.add("无数据");
}
System.out.println("第"+(i+1)+"行数据:"+list.toString());
map.put(i, list);
}
}
} catch (Exception e) {
System.out.println("读取Excel异常:"+e.getMessage());
e.printStackTrace();
} finally {
if (wb != null) {
try {
wb.close();
} catch (IOException e) {
e.printStackTrace();
}
}
}
return map;
}
/**
* 取单元格的值
*/
private String getCellValue(Cell c) {
if (c == null) {
return "无数据";
}
String value = "";
switch (c.getCellType()){
case HSSFCell.CELL_TYPE_NUMERIC://数字
value = c.getNumericCellValue()+"";
break;
case HSSFCell.CELL_TYPE_STRING://字符串
value = c.getStringCellValue();
break;
case HSSFCell.CELL_TYPE_BOOLEAN://boolean
value = c.getBooleanCellValue()+"";
break;
case HSSFCell.CELL_TYPE_FORMULA://公式
value = c.getCellFormula()+"";
break;
case HSSFCell.CELL_TYPE_BLANK://空值
value= "无数据";
break;
case HSSFCell.CELL_TYPE_ERROR:
value = "非法字符";
break;
default:
value= "未知类型";
break;
}
return value;
}
}
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持码农之家。
以上就是本次给大家分享的关于java的全部知识点内容总结,大家还可以在下方相关文章里找到相关文章进一步学习,感谢大家的阅读和支持。
java excel 模板_java对Excel模板的读取相关推荐
- java语言for模板_java版的模板语言
最近心血来潮,开发了一个小工具,为了方便以后定制模板,打算使用模板语言,之前在项目中用过freemark和velocity,对于它们的语法都不喜欢,还是重造个轮子吧,哈哈. 先贴段代码吧: test ...
- java excel 操作方式_Java读写Excel基本操作
Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程式对Microsoft Office格式档案读和写的功能. 接口: HSSF - Microsoft Exce ...
- java导出excel报表_java生成excel报表文件示例
此次简单的操作将数据从数据库导出生成excel报表以及将excel数据导入数据库 首先建立数据库的连接池: package jdbc; import java.io.FileInputStream; ...
- java excel生成_java操作excel表,包括创建、读取、以及修改【via 度娘】
作者的网站上对它的特征有如下描述: ● 支持Excel 95-2000的所有版本 ● 生成Excel 2000标准格式 ● 支持字体.数字.日期操作 ● 能够修饰单元格属性 ● 支持图像和图表 应该说 ...
- java公共excel导入_Java实现Excel的导入功能
上次项目开发过程中需要实现通过excel文件进行导入.我才用了WorkbookFactory方法,因为导入的数据需要处理,所以在程序中我使用List对读入的数据进行了分类.所以大家对数据处理可以不用关 ...
- java excel 导出_java导出Excel通用方法实例
数据导出到Excel几乎是所有客户都会提出的一个需求.下面我就分享一下我的代码. 首先需要引入的jar包: 然后就是正式代码了. package lcy._41_50; import java.io. ...
- java 实验报告模板_Java实验报告模板.doc.doc
Java实验报告模板.doc 实 验 报 告 课程名称Java面向对象程序设计实验名称检查危险品姓名吴超益学号201424134114专业年级14物联网一.实验目的: 本实验的目的是让学生掌握try- ...
- java xlsx读写_Java读写Excel
Java读写Excel 工作中经常需要对Excel进行读写操作,java操作excel文件比较流行的是apache poi包,excel分为xls(2003)和xlsx(2007)两种格式,操作这两种 ...
- java导出类_java导出excel工具类
java导出excel须要使用HSSFWorkbook这个类,须要导入poi-3.6-20091214.jar 工具类调用例如以下: package com.qlwb.business.util; i ...
最新文章
- excel总行数 java_计算Excel工作表列中的行数(提供的Java代码)
- java 获取注释_Java面试题Java语言有哪些注释的方式?
- [html] 一般习惯把js写在</body>前,但有例外的情况吗?说说看
- 改造一下jeecg中的部门树
- Cannot delete .... . Name node is in safe mode
- pion webrtc 示例代码解析 一
- 公钥与私钥 数字签名是什么?
- qt android .so反编译,Qt5 程序初步逆向分析+解析脚本
- 微信读书vscode插件_众所周知,拥有了vscode就拥有了一切
- 好看的流程审批html,审批流程(加班)驳回(流程被删除).html
- VS2019添加自定义发布本地的Nuget(.nupkg文件)
- VS2019创建COM组件
- CF1413A 【Finding Sasuke】
- 2022年忍者必须死3到达无双纪念
- Qt创建停靠悬浮窗口
- 中国新四大发明诞生 主打吃逛买以互联网为主
- 【已解决】“10.1.1.2‘ is blocked because of many connection errors; unblock with ‘mysqladmin flush-hosts‘
- WordPress 衍生产品 BuddyPress 年底发布
- ai作文批改_AI批改作文到底靠不靠谱
- Unity 安装 Device Simulator