`
sfish002
  • 浏览: 43156 次
  • 性别: Icon_minigender_1
  • 来自: 成都
社区版块
存档分类
最新评论

java 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(); 
        } 
    } 


得到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()),不同的单元格格式使用不同的方法。最后加上为止类型,以防万一。
而且在数字类型里,又分为了纯数字和时间格式:
Java代码 
case HSSFCell.CELL_TYPE_NUMERIC: // 数值型 
    if (HSSFDateUtil.isCellDateFormatted(cell)) { 
        //  如果是date类型则 ,获取该cell的date值 
        value = HSSFDateUtil.getJavaDate(cell.getNumericCellValue()).toString(); 
    } else { // 纯数字 
        value = String.valueOf(cell.getNumericCellValue()); 


还有一种迭代的方法:
Java代码 
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数组。
分享到:
评论

相关推荐

    java POI读取excel文件数据

    在这个场景中,我们将详细探讨如何使用Java POI读取Excel文件中的数据,包括获取总行数、列数、单元格内容、合并单元格、行高、列宽以及图片等信息。 首先,确保在项目中已经引入了Apache POI的依赖库。如果你使用...

    java poi 读取excel 2007

    以上就是使用Java POI读取Excel 2007文件并将内容存储到List的基本过程。这个过程可以根据实际需求进行调整,比如处理表头、忽略空行、处理特殊格式的单元格等。在处理大数据量时,还需要考虑性能优化,例如使用迭代...

    Java POI读取excel中数值精度损失问题解决

    Java POI 读取 Excel 中数值精度损失问题解决 Java POI 读取 Excel 中数值精度损失问题解决是指在使用 Java POI 读取 Excel 文件时,遇到数值精度损失的问题。这种问题的出现是因为 Excel 中的数值单元格在读取时,...

    java POI读取Excel文件基本用法Demo

    在本示例"Java POI读取Excel文件基本用法Demo"中,我们将深入探讨如何使用Java POI库来读取Excel文件。 首先,我们需要在项目中引入Apache POI的依赖。对于Maven项目,可以在pom.xml文件中添加以下依赖: ```xml ...

    java poi 读取excel表格

    接着,我们来看看如何使用Java POI读取Excel文件。以下是一个基本示例,展示如何打开一个Excel文件并读取其内容: ```java import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel....

    java 读取excel表格数据 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...

    java poi读取excel xls xlsx相关jar包集合

    java poi读取excel xls xlsx相关jar包集合,包含: dom4j-1.6.1.jar jsr173_1.0_api.jar poi-3.7-20101029.jar poi-ooxml-3.7-20101029.jar poi-ooxml-schemas-3.7-20101029.jar poi-scratchpad-3.7-20101029.jar ...

    java poi读取Excel需要导入的所有包

    Java POI 是一个开源库,...因此,为了确保Java POI能够顺利读取Excel文件,开发者必须确保项目配置中包含了上述所有必要的库文件。同时,根据项目需求,可能还需要更新到最新版本的POI库,以获得更好的性能和兼容性。

    java读写Excel,POI.JAR,Word内容读取

    java读写Excel,POI.JAR,Word内容读取

    使用POI解析excel文件并写入数据库

    这个项目实现的功能是读取excel文件中的数据,解析并写入数据库。 读取的excel文件位于项目目录下的 excel\0805.xlsx 使用IntelliJ IDEA开发此项目 使用MYSQL查看数据库 在MYSQL中运行项目db目录下的sql文件,创建...

    JAVA_poi读取Excel.pdf

    JAVA POI 读取 Excel JAVA POI 是 Apache 的一个子项目,提供了一...本文总结了 JAVA POI 读取 Excel 的知识点,包括 POI 简介、Excel 文件的组织形式、POI 的主要对象、使用 POI 读取 Excel 和使用 POI 写入 Excel。

    java poi处理excel数据

    Java POI是Apache软件基金会下的一个开源项目,主要用于读写Microsoft Office格式的文件,特别是Excel。在Java开发中,当你需要处理Excel数据时,POI库是一个强大的工具。本压缩包包含了一些关键资源,帮助你理解和...

    利用POI读取excel写入到word

    要实现"利用POI读取excel写入到word",我们需要以下步骤: 1. **准备环境**:首先,确保你的项目已经引入了Apache POI的依赖。在给定的压缩包中,"poi - 副本"可能是包含POI库的JAR文件,你需要将其添加到你的项目...

    Java使用apache POI读取Excel2007以上代码以及所需jar包

    本文将详细介绍如何使用Apache POI库来读取Excel 2007及以上版本(即XLSX格式)的文件,并提供所需的jar包信息。 首先,要使用Apache POI读取XLSX文件,你需要确保引入了正确的依赖。Apache POI项目提供了多个组件...

    java poi导出图片到excel示例代码

    在示例代码中,使用了Java POI读取Excel文件,并将其写入到数据库中。首先,需要创建一个Workbook对象,然后使用Workbook对象的getSheet方法获取Excel文件的Sheet对象,最后使用Sheet对象的getRow方法读取Excel文件...

    java poi读取excel表格数据专用jar包 包括(dom4j和xmlbeans包)

    5. **读取Excel数据**:使用POI读取Excel数据的基本步骤包括: - 加载工作簿:创建HSSFWorkbook对象(.xls)或XSSFWorkbook对象(.xlsx)。 - 访问工作表:通过工作簿对象获取Sheet对象,代表Excel中的工作表。 -...

    java_poi实现excel导入导出

    Java POI 实现 Excel 导入导出 Java POI 是一个流行的 Java 库,用于处理 Microsoft Office 文件格式,包括 ...在本文中,我们已经详细介绍了如何使用 Java POI 实现 Excel 导入导出功能,包括读取和写入 Excel 文件。

    POI读取Excel合并单元格并储存

    本文将深入探讨如何使用Java的Apache POI库来读取Excel文件,并处理其中合并单元格的数据,同时将这些数据存储到实体类中以供后续使用。 Apache POI是一个强大的库,允许程序员使用Java来创建、修改和显示Microsoft...

    java+poi读取excel数据 源码

    本源码包提供了一个通用的Java POI读取Excel数据的实现,特别适用于那些需要在服务器端或无桌面环境处理Excel数据的应用。 在描述中提到,源码已经包含了poi.jar包,这是POI项目的主要依赖库,包含了处理Excel文件...

    POI读取excel的内容.zip

    本教程将详细讲解如何使用Apache POI库来读取Excel文件的内容。 首先,为了在Java项目中使用Apache POI,我们需要通过Maven进行依赖管理。在`pom.xml`文件中添加以下依赖: ```xml &lt;groupId&gt;org.apache.poi ...

Global site tag (gtag.js) - Google Analytics