HSSFWorkbook读取97-2003格式 ,XSSFWorkbook读取2007-2013格式

  1. /**
  2. * 读取97-2003格式
  3. * @param filePath 文件路径
  4. * @throws java.io.IOException
  5. */
  6. public static List<Map> readExcel2003(String filePath) throws IOException{
  7. //返回结果集
  8. List<Map> valueList=new ArrayList<Map>();
  9. FileInputStream fis=null;
  10. try {
  11. fis=new FileInputStream(filePath);
  12. HSSFWorkbook wookbook = new HSSFWorkbook(fis);  // 创建对Excel工作簿文件的引用
  13. HSSFSheet sheet = wookbook.getSheetAt(0);   // 在Excel文档中,第一张工作表的缺省索引是0
  14. int rows = sheet.getPhysicalNumberOfRows(); // 获取到Excel文件中的所有行数­
  15. Map<Integer,String> keys=new HashMap<Integer, String>();
  16. int cells=0;
  17. // 遍历行­(第1行  表头) 准备Map里的key
  18. HSSFRow firstRow = sheet.getRow(0);
  19. if (firstRow != null) {
  20. // 获取到Excel文件中的所有的列
  21. cells = firstRow.getPhysicalNumberOfCells();
  22. // 遍历列
  23. for (int j = 0; j < cells; j++) {
  24. // 获取到列的值­
  25. try {
  26. HSSFCell cell = firstRow.getCell(j);
  27. String cellValue = getCellValue(cell);
  28. keys.put(j,cellValue);
  29. } catch (Exception e) {
  30. e.printStackTrace();
  31. }
  32. }
  33. }
  34. // 遍历行­(从第二行开始)
  35. for (int i = 1; i < rows; i++) {
  36. // 读取左上端单元格(从第二行开始)
  37. HSSFRow row = sheet.getRow(i);
  38. // 行不为空
  39. if (row != null) {
  40. //准备当前行 所储存值的map
  41. Map<String, Object> val=new HashMap<String, Object>();
  42. boolean isValidRow = false;
  43. // 遍历列
  44. for (int j = 0; j < cells; j++) {
  45. // 获取到列的值­
  46. try {
  47. HSSFCell cell = row.getCell(j);
  48. String cellValue = getCellValue(cell);
  49. val.put(keys.get(j),cellValue);
  50. if(!isValidRow && cellValue!=null && cellValue.trim().length()>0){
  51. isValidRow = true;
  52. }
  53. } catch (Exception e) {
  54. e.printStackTrace();
  55. }
  56. }
  57. //第I行所有的列数据读取完毕,放入valuelist
  58. if(isValidRow){
  59. valueList.add(val);
  60. }
  61. }
  62. }
  63. } catch (IOException e) {
  64. e.printStackTrace();
  65. }finally {
  66. fis.close();
  67. }
  68. return valueList;
  69. }
  1. /**
  2. * 读取2007-2013格式
  3. * @param filePath 文件路径
  4. * @return
  5. * @throws java.io.IOException
  6. */
  7. public static List<Map> readExcel2007(String filePath) throws IOException{
  8. List<Map> valueList=new ArrayList<Map>();
  9. FileInputStream fis =null;
  10. try {
  11. fis =new FileInputStream(filePath);
  12. XSSFWorkbook xwb = new XSSFWorkbook(fis);   // 构造 XSSFWorkbook 对象,strPath 传入文件路径
  13. XSSFSheet sheet = xwb.getSheetAt(0);            // 读取第一章表格内容
  14. // 定义 row、cell
  15. XSSFRow row;
  16. // 循环输出表格中的第一行内容   表头
  17. Map<Integer, String> keys=new HashMap<Integer, String>();
  18. row = sheet.getRow(0);
  19. if(row !=null){
  20. //System.out.println("j = row.getFirstCellNum()::"+row.getFirstCellNum());
  21. //System.out.println("row.getPhysicalNumberOfCells()::"+row.getPhysicalNumberOfCells());
  22. for (int j = row.getFirstCellNum(); j <=row.getPhysicalNumberOfCells(); j++) {
  23. // 通过 row.getCell(j).toString() 获取单元格内容,
  24. if(row.getCell(j)!=null){
  25. if(!row.getCell(j).toString().isEmpty()){
  26. keys.put(j, row.getCell(j).toString());
  27. }
  28. }else{
  29. keys.put(j, "K-R1C"+j+"E");
  30. }
  31. }
  32. }
  33. // 循环输出表格中的从第二行开始内容
  34. for (int i = sheet.getFirstRowNum() + 1; i <= sheet.getPhysicalNumberOfRows(); i++) {
  35. row = sheet.getRow(i);
  36. if (row != null) {
  37. boolean isValidRow = false;
  38. Map<String, Object> val = new HashMap<String, Object>();
  39. for (int j = row.getFirstCellNum(); j <= row.getPhysicalNumberOfCells(); j++) {
  40. XSSFCell cell = row.getCell(j);
  41. if (cell != null) {
  42. String cellValue = null;
  43. if(cell.getCellType()==XSSFCell.CELL_TYPE_NUMERIC){
  44. if(DateUtil.isCellDateFormatted(cell)){
  45. cellValue = new DataFormatter().formatRawCellContents(cell.getNumericCellValue(), 0, "yyyy-MM-dd HH:mm:ss");
  46. }
  47. else{
  48. cellValue = String.valueOf(cell.getNumericCellValue());
  49. }
  50. }
  51. else{
  52. cellValue = cell.toString();
  53. }
  54. if(cellValue!=null&&cellValue.trim().length()<=0){
  55. cellValue=null;
  56. }
  57. val.put(keys.get(j), cellValue);
  58. if(!isValidRow && cellValue!= null && cellValue.trim().length()>0){
  59. isValidRow = true;
  60. }
  61. }
  62. }
  63. // 第I行所有的列数据读取完毕,放入valuelist
  64. if (isValidRow) {
  65. valueList.add(val);
  66. }
  67. }
  68. }
  69. } catch (IOException e) {
  70. e.printStackTrace();
  71. }finally {
  72. fis.close();
  73. }
  74. return valueList;
  75. }
  76. /**
  77. * 文件操作 获取文件扩展名
  78. *
  79. * @Author: sunny
  80. * @param filename
  81. *            文件名称包含扩展名
  82. * @return
  83. */
  84. public static String getExtensionName(String filename) {
  85. if ((filename != null) && (filename.length() > 0)) {
  86. int dot = filename.lastIndexOf('.');
  87. if ((dot > -1) && (dot < (filename.length() - 1))) {
  88. return filename.substring(dot + 1);
  89. }
  90. }
  91. return filename;
  92. }

HSSFWorkbook和XSSFWorkbook的区别的更多相关文章

  1. Java HSSFworkbook,XSSFworkbook,SXSSFworkbook区别简述

    Java HSSFworkbook,XSSFworkbook,SXSSFworkbook区别简述 一.HSSFworkbook,XSSFworkbook,SXSSFworkbook区别简述 用Java ...

  2. 关于poi导出excel方式HSSFWorkbook(xls).XSSFWorkbook(xlsx).SXSSFWorkbook.csv的总结

    1.HSSFWorkbook(xls) import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermo ...

  3. HSSFWorkbook 与 XSSFWorkbook

    刚开始使用new HSSFWorkbook(new FileInputStream(excelFile))来读取Workbook,对Excel2003以前(包括2003)的版本没有问题,但读取Exce ...

  4. [转载]Java读取Excel中的单元格数据

    目前网上能找到的读取Excel表格中数据的两种比较好的方案:PageOffice好用开发效率高:POI免费.供大家参考,针对具体情况选择具体方案. 1. PageOffice读取excel impor ...

  5. POI操作Excel的三种Workbook的发展和区别

    POI的一些使用方法: 创建流程:(上级为下级的载体) 1.创建Workbook(工作薄): 2.创建Sheet(表单,可以创建多个): 3.创建Row(行): 4.创建Cell(单元格) 接下来分别 ...

  6. java使用poi(XSSFWorkbook)读取excel(.xlsx)文件

    经过一番搜索发现,java操纵excel文件常用的有jxl和poi两种方式,孰好孰坏看自己需求而定.其中最主要的区别在于jxl不支持.xlsx,而poi支持.xlsx这里介绍的使用poi方式(XSSF ...

  7. Java使用POI的SXSSFWorkbook与HSSFWorkbook导出复杂表头

    一.HSSFWorkbook与SXSSFWorkbook的区别: HSSFWorkbook是对Excel2003以前的版本进行操作的,即后缀名为.xls SXSSFWorkbook时对Excel200 ...

  8. Asp.Net Core(.net内核)

    Asp.Net Core(.net内核) //----------------Day1----------------一章    Web基本原理 1节课程说明 web窗体--设计界面--加法使用Chr ...

  9. Java_POI之MS-Excel2003(扩展名.xls)升级至MS-Excel2007及以上版本(扩展名.xlsx)技术过程概要

    Java_POI之MS-Excel2003(扩展名.xls)升级至MS-Excel2007及以上版本(扩展名.xlsx)技术过程概要 作者:Eric.Zhang(花名:穿越者7号) 日期:2015年1 ...

随机推荐

  1. HtmlParser的使用-爬虫学习(三)

    关于这个HtmlParser的学习资料,网上真的很匮乏,这个好用的东西不要浪费啊,所以我在这里隆重的介绍一下. HtmlParser是一个用来解析HTML文件的Java包,主要用于转换盒抽取两个方面. ...

  2. Asp.net MVC4 CodeFirst 使用EFTracingProvider

    一.关于EFTracingProvider EFTracingProvider相关信息见作者博客:关于EFTracingProvider EFTracingProvider Demo下载地址:Trac ...

  3. [原]调试没有符号的 iOS 应用

    说明: 这里的调试是指使用 lldb 远程调试 iOS 应用 设置断点是指在 ObjC 方法上设置断点 使用场景: 1.调试被 strip 了的 iOS 应用 2.调试被 strip 了的 iOS 系 ...

  4. [整理]在命令行执行 UIAutomation

    instruments -t /Developer/Platforms/iPhoneOS.platform/Developer/Library/Instruments/PlugIns/Automati ...

  5. [转]Hooked on DTrace

    source link: 1.http://blog.bignerdranch.com/1907-hooked-on-dtrace-part-1/ 2.http://blog.bignerdranch ...

  6. jquery选择器之属性过滤选择器

    <style type="text/css"> /*高亮显示*/ .highlight{ background-color: gray } </style> ...

  7. 把项目做成jar包

    方法一.在eclipse3.1中把项目做成jar包步骤. 打包前的工作. 在项目下创建一个文件夹,名为META-INF,再在其下创建文件MANIFEST.MF 编辑的内容如下: Manifest-Ve ...

  8. C#:iterator 迭代器/partial class 分布类/泛型

    C#:iterator 迭代器/partial class 分布类/泛型 iterator 迭代器 写个最简单的迭代,(迭代一个字符串数组): 1.实现接口中的方法: 1 using System; ...

  9. 一个简单的EXTJS案例

    aria-form.js Ext.require([ 'Ext.form.*', 'Ext.layout.container.Column', 'Ext.tab.*' ]); Ext.onReady( ...

  10. Java笔记:抽象类、接口

    这篇笔记主要是抽象类和接口,还有简单介绍下三种设计模式:模板模式.工厂模式.命令模式 1.抽象方法和抽象类(1)抽象方法和抽象类都必须使用abstract修饰符来定义,包含抽象方法的类只能被定义成抽象 ...