如何用Apache POI读取Excel

如何用Apache POI读取Excel,第1张

首先POI是开源组织Apache出品的一个开源jar包,提供了方便解析Excel的API,我们可以非常方便的使用它来读取Excel。这里介绍35Final版本。

所需用到的jar包如下:

说到Excel,有2003和2007,格式是不一样的,用POI解析的方法也就不一样,Excel2003主要是使用orgapachepoihssfusermodel包中的类来解析,而Excel2007就是使用orgapachepoixssfusermodel来解析。

解析Excel2003源码

说到Excel,有2003和2007,格式是不一样的,用POI解析的方法也就不一样,Excel2003主要是使用orgapachepoihssfusermodel包中的类来解析,而Excel2007就是使用orgapachepoixssfusermodel来解析。

解析Excel2003源码

StringBuffer content = new StringBuffer();
  HSSFWorkbook workbook = new HSSFWorkbook(is); // 创建对Excel工作簿文件的引用

for (int numSheets = 0; numSheets < workbookgetNumberOfSheets(); numSheets++) {
   if (null != workbookgetSheetAt(numSheets)) {
    HSSFSheet aSheet = workbookgetSheetAt(numSheets); // 获得一个sheet

for (int rowNumOfSheet = 0; rowNumOfSheet <= aSheetgetLastRowNum(); rowNumOfSheet++) {
     if (null != aSheetgetRow(rowNumOfSheet)) {
      HSSFRow aRow = aSheetgetRow(rowNumOfSheet); // 获得一行

for (int cellNumOfRow = 0; cellNumOfRow <= aRowgetLastCellNum(); cellNumOfRow++) {
       if (null != aRowgetCell(cellNumOfRow)) {
        HSSFCell aCell = aRowgetCell(cellNumOfRow); // 获得列值
        
        if (aCellgetCellType() == HSSFCellCELL_TYPE_NUMERIC) {
         contentappend(aCellgetNumericCellValue() + "\t");
        } else if (aCellgetCellType() == HSSFCellCELL_TYPE_BOOLEAN) {
         contentappend(aCellgetBooleanCellValue() + "\t");
        } else if (aCellgetCellType() == HSSFCellCELL_TYPE_STRING) {
         contentappend(aCellgetStringCellValue() + "\t");
        } else if (aCellgetCellType() == HSSFCellCELL_TYPE_FORMULA){
         contentappend(aCellgetCellFormula() + "\t");
        } else {
         continue;
        }
       }
       if(cellNumOfRow == aRowgetLastCellNum()) {
        contentappend("\n");
       }
      }
     }
    }
   }
  }

return contenttoString()trim();

解析Excel2007和2003基本一样,只是将HSSFSheet,HSSFCell等都改成XSSFSheet,XSSFCell即可。

另外要提醒大家的是Excel的样式都是基于一个单元格的,所以用HSSFRowgetRowStyle()拿样式会出问题的,不一定会拿到你想要的样式。处理合并单元格是POI的一个难点,只能通过判断当前单元格是否在合并单元格之中,如果是,那此单元格的值便是这个合并单元格的首位置单元格的值,只有通过这样才能来处理合并单元格。

处理合并单元格的代码:


 public static boolean isMergedRegion(HSSFSheet sheet, HSSFCell cell) {
  //得到一个sheet中有多少个合并单元格
  int sheetmergerCount = sheetgetNumMergedRegions();
  for(int i = 0; i < sheetmergerCount; i++) {
   //得出具体的合并单元格
   CellRangeAddress ca = sheetgetMergedRegion(i);
   //得到合并单元格的起始行, 结束行, 起始列, 结束列
   int firstC = cagetFirstColumn();
   int lastC = cagetLastColumn();
   int firstR = cagetFirstRow();
   int lastR = cagetLastRow();
   //判断该单元格是否在合并单元格范围之内, 如果是, 则返回 true
   if(cellgetColumnIndex() <= lastC && cellgetColumnIndex() >= firstC) {
    if(cellgetRowIndex() <= lastR && cellgetRowIndex() >= firstR) {
     return true;
    }
   }
  }
  return false;
 }


 public static String getMergedRegionValue(HSSFSheet sheet, HSSFCell cell) {
  //获得一个 sheet 中合并单元格的数量
  int sheetmergerCount = sheetgetNumMergedRegions();
  //便利合并单元格
  for(int i = 0; i < sheetmergerCount; i++) {
   //获得合并单元格
   CellRangeAddress ca = sheetgetMergedRegion(i);
   //获得合并单元格的起始行, 结束行, 起始列, 结束列
   int firstC = cagetFirstColumn();
   int lastC = cagetLastColumn();
   int firstR = cagetFirstRow();
   int lastR = cagetLastRow();
   //判断该单元格是否是在合并单元格中, 如果是, 则返回所在合并单元格的首单元格的值
   if(cellgetColumnIndex() <= lastC && cellgetColumnIndex() >= firstC) {
    if(cellgetRowIndex() <= lastR && cellgetRowIndex() >= firstR) {
     HSSFRow fRow = sheetgetRow(firstR);
     HSSFCell fCell = fRowgetCell(firstC);
     //除了合并单元格首单元格的值, 其余的用()来区分
     if (fCellgetCellType() == HSSFCellCELL_TYPE_NUMERIC && hasBorder(cell)) {
      return StringvalueOf(fCellgetNumericCellValue());
     } else if (fCellgetCellType() == HSSFCellCELL_TYPE_BOOLEAN && hasBorder(cell)) {
      return StringvalueOf(fCellgetBooleanCellValue());
     } else if (fCellgetCellType() == HSSFCellCELL_TYPE_STRING && hasBorder(cell)) {
      return fCellgetStringCellValue();
     } else if (fCellgetCellType() == HSSFCellCELL_TYPE_FORMULA && hasBorder(cell)){
      return StringvalueOf(fCellgetCellFormula());
     }
    }
   }
  }
  return "";
 }

以上就是关于如何用Apache POI读取Excel全部的内容,包括:如何用Apache POI读取Excel、、等相关内容解答,如果想了解更多相关内容,可以关注我们,你们的支持是我们更新的动力!

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/9780104.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-01
下一篇 2023-05-01

发表评论

登录后才能评论

评论列表(0条)

保存