- Demo 1
import java.io.File; import java.io.FileInputStream; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import org.apache.poi.poifs.filesystem.POIFSFileSystem; public class FileAnaly { public static void main(String[] args) { try { //获取文件流 POIFSFileSystem pois = new POIFSFileSystem(new FileInputStream(new File("D:/codeimages/账户信息.xls"))); //新建WorkBook HSSFWorkbook wb = new HSSFWorkbook(pois); //获取Sheet(工作薄)总个数 int sheetNumber = wb.getNumberOfSheets(); for (int i = 0; i < sheetNumber; i++) { //获取Sheet(工作薄) HSSFSheet sheet = wb.getSheetAt(i); //开始行数 int firstRow = sheet.getFirstRowNum(); //结束行数 int lastRow = sheet.getLastRowNum(); //判断该Sheet(工作薄)是否为空 boolean isEmpty = false; if(firstRow == lastRow){ isEmpty = true; } if(!isEmpty){ for (int j = firstRow; j <= lastRow; j++) { //获取一行 HSSFRow row = sheet.getRow(j); //开始列数 int firstCell = row.getFirstCellNum(); //结束列数 int lastCell = row.getLastCellNum(); //判断该行是否为空 if(firstCell != lastCell){ for (int k = firstCell; k < lastCell; k++) { //获取一个单元格 HSSFCell cell = row.getCell(k); Object value = null; // 类型说明 // CELL_TYPE_NUMERIC 数值型 0 // CELL_TYPE_STRING 字符串型 1 // CELL_TYPE_FORMULA 公式型 2 // CELL_TYPE_BLANK 空值 3 // CELL_TYPE_BOOLEAN 布尔型 4 // CELL_TYPE_ERROR 错误 5 //获取单元格,值的类型 int cellType = cell.getCellType(); if(cellType == 0){ value = cell.getNumericCellValue(); System.out.print(value+" "); }else if(cellType == 1){ value = cell.getStringCellValue(); System.out.print(value+" "); }else if(cellType == 2){ System.out.print(cell.getCellFormula()); }else if(cellType == 4){ value = cell.getBooleanCellValue(); System.out.print(value+" "); } } } System.out.print("\n"); } } } } catch (Exception e) { e.printStackTrace(); } } }
2. Demo 2
package test.tool.excel; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.text.NumberFormat; import java.util.ArrayList; import java.util.LinkedHashMap; import java.util.List; import java.util.Map; import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFRow; import org.apache.poi.hssf.usermodel.HSSFSheet; import org.apache.poi.hssf.usermodel.HSSFWorkbook; import test.tool.path.PathTool; /* * 操作Excel工具类,建议首先将excel单元格设置成文本(设置单元格格式——数字——文本), * 否则取出的数据可能会发生格式的转变。 * 目前仅支持xls文件,不支持xlsx。 * 目前对于空字符串的约定:当从excel取出来的值是""时,执行往数据库插入数据时,需要加个判断,如果=="",则拼接sql可以处理成字段='' */ public class ExcelTool { /* * 获取excel File * return java.io.file */ public static File getExcelFile(String excel_file_dir){ String excel_file = PathTool.getTestDataPath()+excel_file_dir; File excelFile = new File(excel_file); if(!excelFile.exists()){ throw new RuntimeException(excel_file+" 文件不存在!"); } if(!excelFile.getName().endsWith(".xls")){ throw new RuntimeException(excel_file+" 文件类型不正确,只允许.xls结尾的文件!"); } return excelFile; } /* * 获取指定标签页名称的数据 */ public static List<Map<String,Object>> getExcelRecords(String excel_file_dir,String sheetName){ if(sheetName==null){ throw new RuntimeException("标签页名称不能为空!"); } return getExcelRecords(excel_file_dir, sheetName, -1); } /* * 获取指定标签页索引的数据 */ public static List<Map<String,Object>> getExcelRecords(String excel_file_dir,int sheetIndex){ if(sheetIndex<0){ throw new RuntimeException("指定标签页索引不合法,请输入非负数!"); } return getExcelRecords(excel_file_dir, null, sheetIndex); } /* * 获取指定excel文件、指定标签页(标签页名称、标签页索引)的内容,返回值格式:List<List<Object>> * 入参excel_file格式:bpm\\test1.xls,bsp\\test2.xls */ private static List<Map<String,Object>> getExcelRecords(String excel_file_dir,String sheetName,int sheetIndex){ File excelFile = getExcelFile(excel_file_dir); List<Map<String,Object>> recordList = new ArrayList<Map<String,Object>>(); HSSFWorkbook workbook=null; try { workbook = new HSSFWorkbook(new FileInputStream(excelFile)); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } //获取指定标签页 HSSFSheet sheet = null; if(sheetName==null){ sheet = workbook.getSheetAt(sheetIndex); if(sheet==null){ throw new RuntimeException(sheetIndex+" 标签页不存在!"); } }else{ sheet = workbook.getSheet(sheetName); if(sheet==null){ throw new RuntimeException(sheetName+" 标签页不存在!"); } } //总行数 int rows = sheet.getPhysicalNumberOfRows(); if (rows < 2) { throw new RuntimeException(excelFile.getName()+" 内容为空,请重新编辑!"); } //不为空的单元格数 ,第一行是标题列 HSSFRow keyRow = sheet.getRow(0); int cellNumber = keyRow.getPhysicalNumberOfCells(); //循环遍历,第一行是标题,所以从 1 开始遍历(0表示第一行,1表示第二行) for (int r = 1; r < rows; r++) { Map<String,Object> record = new LinkedHashMap<String,Object>();//使用HashMap的话,存进去的顺序与取出来的顺序是不一致的,此处需要使用LinkedHashMap HSSFRow row = sheet.getRow(r); Object value = null; for (int c = 0; c < cellNumber; c++) //共cellNumber列 { HSSFCell cell = row.getCell(c); //如果单元格不为空 if (cell != null) { switch (cell.getCellType()) { case HSSFCell.CELL_TYPE_FORMULA: break; case HSSFCell.CELL_TYPE_NUMERIC: //对数字进行格式化,使其不自动转化为科学计数法。 java.text.NumberFormat nf = java.text.NumberFormat.getInstance(); nf.setGroupingUsed(false); value = nf.format( new Double(cell.getNumericCellValue())); break; case HSSFCell.CELL_TYPE_STRING: value = cell.getStringCellValue(); break; case HSSFCell.CELL_TYPE_BLANK: value = null; break; default: value = null; } }else{ value=null; } record.put(keyRow.getCell(c).getStringCellValue(),value); } recordList.add(record); } return recordList; } /* * 获取excel的sheet个数 */ public static int getNumberOfSheets(String excel_file_dir){ File excelFile = getExcelFile(excel_file_dir); HSSFWorkbook workbook=null; int numberOfSheets = 0; try { workbook = new HSSFWorkbook(new FileInputStream(excelFile)); numberOfSheets = workbook.getNumberOfSheets(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return numberOfSheets; } /* * 根据sheetIndex获取sheetName */ public static String getSheetNameBySheetIndex(String excel_file_dir,int sheetIndex){ File excelFile = getExcelFile(excel_file_dir); HSSFWorkbook workbook=null; String sheetName = null; try { workbook = new HSSFWorkbook(new FileInputStream(excelFile)); sheetName = workbook.getSheetName(sheetIndex); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return sheetName; } /* * 获取指定选项卡(索引)的行数 */ public static int getRowsOfSheet(String excel_file_dir,int sheetIndex){ File excelFile = getExcelFile(excel_file_dir); HSSFWorkbook workbook=null; int rowsOfSheet = 0; try { workbook = new HSSFWorkbook(new FileInputStream(excelFile)); rowsOfSheet = workbook.getSheetAt(sheetIndex).getPhysicalNumberOfRows(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return rowsOfSheet; } /* * 获取指定选项卡(名称)的行数 */ public static int getRowsOfSheet(String excel_file_dir,String sheetName){ File excelFile = getExcelFile(excel_file_dir); HSSFWorkbook workbook=null; int rowsOfSheet = 0; try { workbook = new HSSFWorkbook(new FileInputStream(excelFile)); rowsOfSheet = workbook.getSheet(sheetName).getPhysicalNumberOfRows(); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return rowsOfSheet; } /* * 获取指定sheet、指定row、指定colum对应的cell的value * return:List[title,value],第一个元素是title,第二个元素是value * row/cell都是从0开始计算 */ public static List<String> getCell(String excel_file_dir,int sheetIndex,int rowIndex,int cellIndex){ File excelFile = getExcelFile(excel_file_dir); List<String> keyValueList = new ArrayList<String>(); HSSFWorkbook workbook=null; String key = null; String value = null; try { workbook = new HSSFWorkbook(new FileInputStream(excelFile)); key = workbook.getSheetAt(sheetIndex).getRow(0).getCell(cellIndex).getStringCellValue();//第一行(row 0)是标题列 HSSFCell cell = workbook.getSheetAt(sheetIndex).getRow(rowIndex).getCell(cellIndex); if(cell==null){ value = null; }else{ if(cell.getCellType()==HSSFCell.CELL_TYPE_NUMERIC){//如果是数字类型 NumberFormat nf = NumberFormat.getInstance(); nf.setGroupingUsed(false); value = nf.format( new Double(cell.getNumericCellValue())); }else if(cell.getCellType()==HSSFCell.CELL_TYPE_STRING){ //如果是文本类型 value = cell.getStringCellValue(); }else{//否则全部视为null value=null; } } keyValueList.add(key); keyValueList.add(value); } catch (FileNotFoundException e) { e.printStackTrace(); } catch (IOException e) { e.printStackTrace(); } return keyValueList; } }
相关推荐
采用poi3.8解析excel文件,内含实例代码和jar包
使用poi解析excel文件,并将数据写入到数据库 项目说明 这个项目实现的功能是读取excel文件中的数据,解析并写入数据库。 读取的excel文件位于项目目录下的 excel\0805.xlsx 使用IntelliJ IDEA开发此项目 使用MYSQL...
1.不分版本,2003/2007完美解析 2.调用方便 3.输出直观 4.解析excel工程demo
在web 开发的时候时常会使用到上传一个execl 文件的技术,然后在吧execl中的数据都添加到数据库中,而POI就是对execl 文件的解析 ,和创建一个execl 文件提供下载。
Java用poi读取excel文件Java用poi读取excel文件Java用poi读取excel文件
NULL 博文链接:https://illy.iteye.com/blog/805803
java web开发 poi 解析excel文件
主要介绍了java 中 poi解析Excel文件版本问题解决办法的相关资料,需要的朋友可以参考下
事件驱动解析是把文件转换成xml,然后一边读取一边解析,这样就对内存的占用就会很少,可以很好的处理poi出现OOM的问题。 maven添加需要的jar包 <groupId>org.apache.poi <artifactId>poi <version>3.15 ...
Excel解析Excel解析Excel解析Excel解析Excel解析Excel解析Excel解析Excel解析
基于新版本的POI编写的读取Excel文件数据的工具类,可根据绝对路径、File对象、InputSteam对象读取解析Excel文件内容,并返回List<List<String>>格式结果,其中包含对单元格公式的处理。
Java使用poi的jar包解析excel,里面有个ExcelUtil工具类, 非常实用,里面有main函数可以测试,导入到eclipse里面就可以运行, 有测试excel文件,需要的jar都在里面, 导入就可以运行.
poi读写excel文件,解析xls文件中的内容:得到行数据,返回行数据数组
poijar包解析excel文件
使用poi读取写入复杂excel内容包括样式,工具类
poi解析excel功能参数说明 此项目是基于springMVC实现的,基本流程为从前台jsp页面使用Ajax文件上传导入excel文件(.xls(97-03)/.xlsx(07以后)),传到后台controller调用相应工具类解析后返回指定参数做后续处理. 1....
POI是Apache开源项目之一,对Office文件的操作拥有强大的功能。附件中为常用的操作之一:Excel解析,支持Excel2003和2007的解析,示例仅供参考。
poi读取大文件Excel,使用xml格式解析,速度实测50mb文件13s,可指定sheet页内容,带工具类和测试类
这次的项目中遇到了Excel批量添加的数据,使用到了Poi解析Execl技术。本人就做了一个Demo,项目使用的是maven,需要的jar都在上面。