这篇文章主要知识点是关于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<Integer, List<String>> readExcel(String filePath) throws FileNotFoundException, FileFormatException { // 检查和获取workbook对象 this.preReadCheck(filePath); Workbook wb = null; Map<Integer,List<String>> map = new HashMap<Integer, List<String>>(); 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<rowcount;i++) { //这里用最原始的for循环来保证每行都会被读取 List<String> list = new ArrayList<String>(); Row row = sheet.getRow(i); if(null!=row){ for (int j=0;j<cellcount;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<cellcount;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的全部知识点内容总结,大家还可以在下方相关文章里找到相关文章进一步学习,感谢大家的阅读和支持。
Copyright 2018-2020 www.xz577.com 码农之家
版权投诉 / 书籍推广 / 赞助:520161757@qq.com
java读写excel文件实现POI解析Excel的方法
在日常工作中,我们常常会进行文件读写操作,除去我们最常用的纯文本文件读写,更多时候我们需要对Excel中的数据进行读取操作,本文将介绍Excel读写的常用方法,希望对大家学习Java读写Excel会有帮助。 package com.zhx.base.utils;import org.apache.poi.hssf.usermodel.HSSFWorkbook;import org.apache.poi.ss.usermodel.*;import org.apache.poi.xssf.usermodel.XSSFWorkbook;import java.io.FileInputStream;import java.io.IOException;import java.io.InputStream;import java.util.ArrayList;import java.util.List;/** * POI解析Excel */public class ExcelReaderUtil { /** * 根据fileType不同读取excel文件 * * @param path * @param path * @throws IOException */ public static ListListString readExcel(String path) { String fileType = path.substring(path.lastIndexOf(".") + 1); // return a list contains many list ListListString lists = new ArrayListListString(); //读取excel文件 InputStream is = null; try { is = new FileInputStream(pa……
Java poi导出Excel下载到客户端
Java poi 导出Excel并下载到客户端,具体内容如下 Maven配置,包含了其他文件格式的依赖,就全贴出来了 dependency groupIdorg.apache.poi/groupId artifactIdpoi-excelant/artifactId version3.12/version /dependency dependency groupIdorg.apache.poi/groupId artifactIdpoi-scratchpad/artifactId version3.12/version /dependency dependency groupIdorg.apache.poi/groupId artifactIdpoi-ooxml/artifactId version3.8/version /dependency dependency groupIdorg.apache.poi/groupId artifactIdpoi-ooxml-schemas/artifactId version3.8/version /dependency Service层 @Override public void export(Long sblsh, String excelName, OutputStream out) { try { // 第一步,创建一个webbook,对应一个Excel文件 HSSFWorkbook wb = new HSSFWorkbook(); //生成一个表格 HSSFSheet sheet = wb.createSheet(excelName); // 第三步,在sheet中添加表头第0行 HSSFRow row = sheet.createRow(0); // 第四步,创建单元格,并设置值表头 设置表头居中 HSSFCellStyle style = w……
java实现的导出Excel工具类实例
本文实例讲述了java实现的导出Excel工具类。分享给大家供大家参考,具体如下: ExcelExportUtil: package com.excel;import java.io.FileOutputStream;import java.io.IOException;import java.io.OutputStream;import java.util.HashSet;import java.util.Map;import java.util.Set;import java.util.regex.Pattern;import jxl.Workbook;import jxl.write.Label;import jxl.write.Number;import jxl.write.NumberFormat;import jxl.write.WritableCellFormat;import jxl.write.WritableSheet;import jxl.write.WritableWorkbook;import jxl.write.WriteException;import jxl.write.biff.RowsExceededException;/** * 生成excel表格 * * @author * */public class ExcelExportUtil { /** * 构造器 * */ public ExcelExportUtil() { } /** * 生成具有一定格式excel * * @param sheetName * sheet名称,默认为sheet1 * @param nf * 数字类型的格式 如:jxl.write.NumberFormat nf = new * jxl.write.NumberFormat("#.##");默认无格式 * @param content * 二维数组,要生成excel的数据来源 * @para……
Java实现生成Excel树形表头完整代码示例
本文主要分享了Java实现生成Excel树形表头完整代码示例,没有什么好解释的,直接看看代码过程。 源数据格式: String[] targetNames = { "指标名称", "单位", "xx_yy1", "xx_yy2_zz1", "xx_yy2_zz2", "2017年5月_主营业务收入_累计", "2017年5月_主营业务收入_同比", "2017年5月_主营业务收入_本月", "2017年5月_主营业务收入_环比", "2017年5月_利润_累计", "2017年5月_利润_同比", "2017年5月_利润_本月", "2017年5月_利润_环比", "2017年6月_主营业务收入_累计", "2017年6月_主营业务收入_同比", "2017年6月_主营业务收入_本月", "2017年6月_主营业务收入_环比", "2017年6月_利润_累计", "2017年6月_利润_同比", "2017年6月_利润_本月", "2017年6月_利润_环比" }; 生成如下Excel: 第一行不属于树形表头。 代码 SplitCell: package com.zzj.excel;public class SplitCell {private String key;private String parentKey;private String value;private int colu……