1, 对于类似电话号码或手机一类的大数值读取问题
- // 取值后会带一个E的问题
- double cellValue = row.getCell(k).getNumericCellValue();
- fieldValues[k] = new DecimalFormat("#").format(cellValue);
2, 对于数值型单元的纯数值和日期型的处理
- case HSSFCell.CELL_TYPE_NUMERIC: // 数值型
- if (HSSFDateUtil.isCellDateFormatted(cell)) {
- // 如果是date类型则 ,获取该cell的date值
- value = HSSFDateUtil.getJavaDate(cell.getNumericCellValue()).toString();
- } else { // 纯数字
- value = String.valueOf(cell.getNumericCellValue());
- }
转: POI读取Excel浅谈
先看代码,挨句解释:
一般遍历使用两种方式,1:得到总的行数和每行的列数,然后循环。2:使用迭代
先看第一种:
- Java代码
- package com.golden.test;
- 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;
- /**
- *
- * @author 崔素强
- *
- */
- public class PoiReadXls2 {
- public static void main(String[] args) {
- File f = new File("c:\\a.xls");
- try {
- FileInputStream is = new FileInputStream(f);
- HSSFWorkbook wbs = new HSSFWorkbook(is);
- HSSFSheet childSheet = wbs.getSheetAt(0);
- // System.out.println(childSheet.getPhysicalNumberOfRows());
- System.out.println("有行数" + childSheet.getLastRowNum());
- for (int j = 0; j < childSheet.getLastRowNum(); j++) {
- HSSFRow row = childSheet.getRow(j);
- // System.out.println(row.getPhysicalNumberOfCells());
- // System.out.println("有列数" + row.getLastCellNum());
- if (null != row) {
- for (int k = 0; k < row.getLastCellNum(); k++) {
- HSSFCell cell = row.getCell(k);
- if (null != cell) {
- switch (cell.getCellType()) {
- case HSSFCell.CELL_TYPE_NUMERIC: // 数字
- System.out.print(cell.getNumericCellValue()
- + " ");
- break;
- case HSSFCell.CELL_TYPE_STRING: // 字符串
- System.out.print(cell.getStringCellValue()
- + " ");
- break;
- case HSSFCell.CELL_TYPE_BOOLEAN: // Boolean
- System.out.println(cell.getBooleanCellValue()
- + " ");
- break;
- case HSSFCell.CELL_TYPE_FORMULA: // 公式
- System.out.print(cell.getCellFormula() + " ");
- break;
- case HSSFCell.CELL_TYPE_BLANK: // 空值
- System.out.println(" ");
- break;
- case HSSFCell.CELL_TYPE_ERROR: // 故障
- System.out.println(" ");
- break;
- default:
- System.out.print("未知类型 ");
- break;
- }
- } else {
- System.out.print("- ");
- }
- }
- }
- System.out.println();
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- }
- package com.golden.test;
- 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;
- /**
- *
- * @author 崔素强
- *
- */
- public class PoiReadXls2 {
- public static void main(String[] args) {
- File f = new File("c:\\a.xls");
- try {
- FileInputStream is = new FileInputStream(f);
- HSSFWorkbook wbs = new HSSFWorkbook(is);
- HSSFSheet childSheet = wbs.getSheetAt(0);
- // System.out.println(childSheet.getPhysicalNumberOfRows());
- System.out.println("有行数" + childSheet.getLastRowNum());
- for (int j = 0; j < childSheet.getLastRowNum(); j++) {
- HSSFRow row = childSheet.getRow(j);
- // System.out.println(row.getPhysicalNumberOfCells());
- // System.out.println("有列数" + row.getLastCellNum());
- if (null != row) {
- for (int k = 0; k < row.getLastCellNum(); k++) {
- HSSFCell cell = row.getCell(k);
- if (null != cell) {
- switch (cell.getCellType()) {
- case HSSFCell.CELL_TYPE_NUMERIC: // 数字
- System.out.print(cell.getNumericCellValue()
- + " ");
- break;
- case HSSFCell.CELL_TYPE_STRING: // 字符串
- System.out.print(cell.getStringCellValue()
- + " ");
- break;
- case HSSFCell.CELL_TYPE_BOOLEAN: // Boolean
- System.out.println(cell.getBooleanCellValue()
- + " ");
- break;
- case HSSFCell.CELL_TYPE_FORMULA: // 公式
- System.out.print(cell.getCellFormula() + " ");
- break;
- case HSSFCell.CELL_TYPE_BLANK: // 空值
- System.out.println(" ");
- break;
- case HSSFCell.CELL_TYPE_ERROR: // 故障
- System.out.println(" ");
- break;
- default:
- System.out.print("未知类型 ");
- break;
- }
- } else {
- System.out.print("- ");
- }
- }
- }
- System.out.println();
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- }
- }
得到Excel的文件然后读取,这个很简单。关键有两个地方,也许在网上会看到有的这样使用有的那样使用。
System.out.println("有行数" + childSheet.getLastRowNum());
System.out.println(childSheet.getPhysicalNumberOfRows());
System.out.println("有列数" + row.getLastCellNum());
System.out.println(row.getPhysicalNumberOfCells());
如果人都拷贝代码进行使用了,不知道有什么区别。太多的区别不知道,但是有一点我发现了,那就是如果中间各行或者隔列的话getPhysicalNumberOfRows和getPhysicalNumberOfCells就不能读取到所有的行和列了。
再者,一定要对单元格的格式进行判断switch (cell.getCellType()),不同的单元格格式使用不同的方法。最后加上为止类型,以防万一。
而且在数字类型里,又分为了纯数字和时间格式:
- case HSSFCell.CELL_TYPE_NUMERIC: // 数值型
- if (HSSFDateUtil.isCellDateFormatted(cell)) {
- // 如果是date类型则 ,获取该cell的date值
- value = HSSFDateUtil.getJavaDate(cell.getNumericCellValue()).toString();
- } else { // 纯数字
- value = String.valueOf(cell.getNumericCellValue());
- }
- case HSSFCell.CELL_TYPE_NUMERIC: // 数值型
- if (HSSFDateUtil.isCellDateFormatted(cell)) {
- // 如果是date类型则 ,获取该cell的date值
- value = HSSFDateUtil.getJavaDate(cell.getNumericCellValue()).toString();
- } else { // 纯数字
- value = String.valueOf(cell.getNumericCellValue());
- }
还有一种迭代的方法:
- package com.golden.test;
- import java.io.File;
- import java.io.FileInputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import java.util.Iterator;
- 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;
- /**
- *
- * @author 崔素强
- *
- */
- public class PoiReadXls {
- @SuppressWarnings( { "unchecked", "deprecation" })
- public static void main(String[] args) {
- File f = new File("c:\\a.xls");
- try {
- InputStream input = new FileInputStream(f);
- POIFSFileSystem fs = new POIFSFileSystem(input);
- HSSFWorkbook wb = new HSSFWorkbook(fs);
- HSSFSheet sheet = wb.getSheetAt(0);
- Iterator rows = sheet.rowIterator();
- while (rows.hasNext()) {
- HSSFRow row = (HSSFRow) rows.next();
- // System.out.print("行:" + row.getRowNum() + " ");
- Iterator cells = row.cellIterator();
- while (cells.hasNext()) {
- HSSFCell cell = (HSSFCell) cells.next();
- // System.out.println("列:" + cell.getCellNum());
- switch (cell.getCellType()) {
- case HSSFCell.CELL_TYPE_NUMERIC: // 数字
- System.out.print(cell.getNumericCellValue() + " ");
- break;
- case HSSFCell.CELL_TYPE_STRING: // 字符串
- System.out.print(cell.getStringCellValue() + " ");
- break;
- case HSSFCell.CELL_TYPE_BOOLEAN: // Boolean
- System.out.println(cell.getBooleanCellValue() + " ");
- break;
- case HSSFCell.CELL_TYPE_FORMULA: // 公式
- System.out.print(cell.getCellFormula() + " ");
- break;
- case HSSFCell.CELL_TYPE_BLANK: // 空值
- System.out.println(" ");
- break;
- case HSSFCell.CELL_TYPE_ERROR: // 故障
- System.out.println(" ");
- break;
- default:
- System.out.print("未知类型 ");
- break;
- }
- }
- System.out.println();
- }
- } catch (IOException ex) {
- ex.printStackTrace();
- }
- }
- }
- package com.golden.test;
- import java.io.File;
- import java.io.FileInputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import java.util.Iterator;
- 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;
- /**
- *
- * @author 崔素强
- *
- */
- public class PoiReadXls {
- @SuppressWarnings( { "unchecked", "deprecation" })
- public static void main(String[] args) {
- File f = new File("c:\\a.xls");
- try {
- InputStream input = new FileInputStream(f);
- POIFSFileSystem fs = new POIFSFileSystem(input);
- HSSFWorkbook wb = new HSSFWorkbook(fs);
- HSSFSheet sheet = wb.getSheetAt(0);
- Iterator rows = sheet.rowIterator();
- while (rows.hasNext()) {
- HSSFRow row = (HSSFRow) rows.next();
- // System.out.print("行:" + row.getRowNum() + " ");
- Iterator cells = row.cellIterator();
- while (cells.hasNext()) {
- HSSFCell cell = (HSSFCell) cells.next();
- // System.out.println("列:" + cell.getCellNum());
- switch (cell.getCellType()) {
- case HSSFCell.CELL_TYPE_NUMERIC: // 数字
- System.out.print(cell.getNumericCellValue() + " ");
- break;
- case HSSFCell.CELL_TYPE_STRING: // 字符串
- System.out.print(cell.getStringCellValue() + " ");
- break;
- case HSSFCell.CELL_TYPE_BOOLEAN: // Boolean
- System.out.println(cell.getBooleanCellValue() + " ");
- break;
- case HSSFCell.CELL_TYPE_FORMULA: // 公式
- System.out.print(cell.getCellFormula() + " ");
- break;
- case HSSFCell.CELL_TYPE_BLANK: // 空值
- System.out.println(" ");
- break;
- case HSSFCell.CELL_TYPE_ERROR: // 故障
- System.out.println(" ");
- break;
- default:
- System.out.print("未知类型 ");
- break;
- }
- }
- System.out.println();
- }
- } catch (IOException ex) {
- ex.printStackTrace();
- }
- }
- }
这种方法,如果数据的紧凑的,使用还是方便的,但是我发现,如果是空行或者是空列,他就会隔过去。具体的自己试试就知道了。
另外,也能看到这里得到Excel文件的方式是通过File,如果要引用到Struts2里,这是很简单的,因为Struts2上传时Action里定义的就是File或者File数组。
相关推荐
在IT行业中,Apache POI是一个广泛使用的开源库,专门用于处理Microsoft Office格式的文件,如Excel、Word和PowerPoint。本篇文章将详细讲解如何利用Apache POI库来读取Excel数据并将其写入到Word文档中。 首先,...
在Java编程领域,Apache POI库是一个非常重要的工具,它允许开发者处理Microsoft Office格式的文件,包括Excel(.xlsx和.xls)文档。本教程将详细讲解如何使用Apache POI库来读取Excel文件的内容。 首先,为了在...
总之,Apache POI是Java开发人员处理Excel文件的强大工具,通过理解其API结构和工作原理,我们可以方便地读取和处理Excel中的带格式数据。无论是简单的数据导出还是复杂的业务逻辑,POI都能胜任。在阅读这篇博客...
在Java编程环境中,Apache POI库是一个非常重要的工具,它允许开发者读取、写入以及修改Microsoft Office格式的文件,包括Excel的.xls和.xlsx格式。标题提到的"poi读取excel文件",指的是使用Apache POI库来处理...
Apache POI 是一个流行的开源库,主要用于处理Microsoft Office格式的文件,尤其是Excel。在Java编程环境中,如果你需要读取或写入Excel文件,POI 提供了强大的支持。本教程将深入讲解如何使用POI的HSSF组件来处理...
Apache POI 是一个开源项目,专门用于处理Microsoft Office格式的文件,包括Excel。在Java世界里,当你需要处理Excel 2007及以上版本(即XLSX格式)的文件时,Apache POI是一个非常实用的库。由于JXL库不支持XLSX...
android5使用poi读取excel,android5使用poi读取excel,android5使用poi读取excel,android5使用poi读取excel
POI读取excel的例子
Apache POI 是一个开源项目,它允许开发者创建、修改和显示MS Office格式的文件,其中就包括Excel。 在Java开发中,Apache POI库提供了API来读取、写入和操作Excel文件。读取Excel文件时,主要涉及到的工作包括打开...
实现了JAVA 窗口,读取EXCEL文件,用poi读取EXCEL内容只是一个小例子
Apache POI是一个强大的Java库,专门用于处理Microsoft Office格式的文件,尤其是Excel。在这个场景中,我们关注的是如何使用POI来创建、读取和操作Excel文档。在Web项目中,这种功能通常用于数据导入导出,报表生成...
Apache POI是一个流行的开源项目,它允许程序员创建、修改和显示Microsoft Office格式的文件,包括Excel(.xls和.xlsx)。在这个“android POI 读取excel 精简jar”中,我们看到了几个关键的库文件,它们是专门为...
Apache POI是一个强大的库,允许程序员使用Java来创建、修改和显示Microsoft Office格式的文件,包括Excel(XLS和XLSX)。在我们的场景中,我们将关注如何读取Excel文件,尤其是处理那些合并了单元格的行与列,因为...
apache poi 读取 Excel 的 jar 包 博文链接:https://wxinpeng.iteye.com/blog/231895
7. **代码示例**:在提供的"读取excel2007和2003兼容例子"中,应包含一个Factory类,如`WorkbookFactory`,它有一个静态方法`getWorkbook(String filePath)`。这个方法会检查文件扩展名,并返回相应的`Workbook`实例...
### POI Excel 模板读取并导出带公式的Excel文档 #### 一、概述 在实际工作中,经常需要批量处理数据,并将其导出到Excel文件中,特别是在需要复杂计算的情况下,例如工资单、统计数据汇总等场景。利用Apache POI...
java读取excel 表格数据。 public static void main(String[] args) { String[][] content=POIExcelUtils.read("E:\\1.xlsx"); for(int i=0;i;i++) { if(content[i]!=null){ for(int j=0;j[i].length;j...
Apache POI 是一个开源项目,专门用于处理Microsoft Office格式的文件,如Excel、Word和PowerPoint。在Java环境中,如果你需要使用POI库来读取、写入或操作Excel文件,你需要确保你的项目中包含了正确的JAR文件。在...
在Java编程环境中,Apache POI库是...总的来说,Apache POI是一个强大的Java库,它使得开发者能够方便地在Java程序中处理Excel文件,无论是读取数据还是生成报告。正确地引入和使用这些jar包,可以极大地提高开发效率。
Java POI库是Apache软件基金会开发的一个开源项目,专门用于处理Microsoft Office格式的文件,如Word、PowerPoint和尤其在本场景中提到的Excel。它提供了API,使得开发者能够使用Java来读取、写入和修改Excel文件。...