`
HogwartsRow
  • 浏览: 59827 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
社区版块
存档分类
最新评论

读取Excel内容的工具类PoiExcelUtil

阅读更多

import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.text.DecimalFormat;
import java.util.ArrayList;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class PoiExcelUtil {

    /**
     * 获取Excel文件的内容
     * @param in 文件流
     * @param isXls  xls 或 Xlsx
     * @return
     */
    public static List<String[]> readExcel(InputStream in, boolean isXls) {
        List<String[]> list = new ArrayList<String[]>();
        Workbook workbook = null;

        try {
            if (isXls) {
                workbook = new HSSFWorkbook(in);//97-2003 Excel工作簿对象
            } else {
                workbook = new XSSFWorkbook(in);//2007 Excel工作簿对象
            }

            for (int i = 0; i < workbook.getNumberOfSheets(); i++) {
                Sheet sheet = workbook.getSheetAt(i);//Excel工作表对象 

                for (int j = sheet.getFirstRowNum(); j <= sheet.getLastRowNum(); j++) {
                    if(j == 0){
                        continue;//跳过Header
                    }
                    Row row = sheet.getRow(j);//Excel工作表的行

                    String[] cellValues = new String[row.getLastCellNum()];
                    for (int k = row.getFirstCellNum(); k < row.getLastCellNum(); k++) {
                        Cell cell = row.getCell(k, Row.RETURN_BLANK_AS_NULL);//Excel工作表指定行的单元格

                        if(null == cell){
                            cellValues[k] = "";
                        }else{
                            //判断单元格值类型
                            switch(cell.getCellType()){
                            case Cell.CELL_TYPE_STRING://字符串类型
                                cellValues[k] = cell.getRichStringCellValue().getString();
                                break;
                            case Cell.CELL_TYPE_NUMERIC://数值类型
                                if(HSSFDateUtil.isCellDateFormatted(cell)){
                                    cellValues[k] = cell.getDateCellValue().toString();
                                }else{
                                    DecimalFormat decimalFormat = new DecimalFormat("#");
                                    cellValues[k] = decimalFormat.format(cell.getNumericCellValue());
                                }
                                break;
                            case Cell.CELL_TYPE_FORMULA://公式 
                                cellValues[k] = cell.getCellFormula();
                                break;
                            case Cell.CELL_TYPE_ERROR|Cell.CELL_TYPE_BLANK:
                                cellValues[k] = "";
                                break;
                            case Cell.CELL_TYPE_BOOLEAN:
                                cellValues[k] = String.valueOf(cell.getBooleanCellValue());
                                break;
                            default:
                                cellValues[k] = "";
                            }
                        }
                    }
                    list.add(cellValues);
                }

            }

        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }

        return list;
    }
   
    public static void main(String[] args) {
       
        File file = new File("C:\\Users\\Administrator\\Desktop\\LOLO DATA\\majia20150515.xls");
       
        boolean isXls = file.getName().endsWith(".xls")||file.getName().endsWith(".XLS");
        InputStream in = null;
        try {
            in = new FileInputStream(file);
        } catch (FileNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        List<String[]> list = PoiExcelUtil.readExcel(in, isXls);
       
        for(Object[] obj : list){
           
            StringBuffer buffer = new StringBuffer();
            for (Object object : obj) {
                buffer.append(object).append("  ");
            }
            System.out.println(buffer.toString());
        }
        System.out.println("list size : " + list.size());
    }
}

1
0
分享到:
评论

相关推荐

    Java读取Excel内容

    Java读取Excel内容 v Java读取Excel内容 Java读取Excel内容

    java上传并读取excel工具类

    3. **读取Excel文件**: 使用Apache POI,我们可以通过`XSSFWorkbook`(对于.xlsx)或`HSSFWorkbook`(对于.xls)来打开Excel文件。以下是一个简单的示例: ```java Workbook workbook = new XSSFWorkbook(new ...

    操作Excel工具类,导出Excel方法,读取Excel中的数据

    操作Excel工具类,导出Excel方法,读取Excel中的数据,导入导出采用excel2003 版本

    读取Excel内容实例VB6.0源代码

    在VB6.0环境下,开发人员经常需要处理与Excel数据的交互,比如读取Excel文件中的内容。这个“读取Excel内容实例VB6.0源代码”提供的就是一个实用的示例,帮助开发者快速掌握如何利用Visual Basic 6.0来读取Excel文件...

    java读取excel

    ReadExcelUtil 工具类提供了多种方法来读取 Excel 文件,包括读取指定Sheet的记录行数、读取指定行的内容等。 打开 Excel 文件 首先,需要打开 Excel 文件,通过 open() 方法可以实现这一步骤,该方法将读取 Excel...

    util_ExcelUtils工具类_

    在Java编程中,`util_ExcelUtils`工具类是一个用于操作Excel文件的实用程序类,它可以帮助开发者方便地读取Excel文件中的数据以及生成新的Excel文件。Excel文件通常被广泛用于数据存储、报告生成和数据分析等领域,...

    C++读取excel数据

    读取环境为Win10+VS2015,个人参考资料封装的excel读取模块用来读取Excel2007中的数据,文件为压缩文件,亲测可用。

    sql server 直接读取excel

    在SQL Server中,直接读取Excel文件是一种常见的需求,特别是在数据整合、分析或者报表生成时。标题和描述中提到的方法允许我们避免将Excel数据导入到数据库中,而是直接在SQL Server中对Excel文件进行查询或处理。...

    spring boot读取Excel操作示例

    创建一个名为 OfficeUtils 的工具类,该类提供了读取 Excel 文件的方法。该类使用 Apache POI 库读取 Excel 文件,并将数据存储在 Map 中。 ```java public class OfficeUtils { protected static final Logger ...

    C# winform 读取Excel文件 表名及内容

    在本场景中,我们将探讨如何在Winform应用中读取Excel文件,包括表名和内容。这里使用的开发工具是Visual Studio 2010,它支持.NET Framework 4.0,这使得我们可以利用Microsoft Office Interop库来操作Excel文件。 ...

    脱离Office读取Excel表工具

    标题"脱离Office读取Excel表工具"指出我们的目标是创建一个独立于Microsoft Office环境的解决方案,用于读取Excel文件。这通常涉及到使用第三方库或者API,以便在没有Office组件的环境中也能实现文件的读取和操作。 ...

    delphi7如何读取excel文件

    "Delphi7 读取 Excel 文件" Delphi7 是一个功能强大的开发环境,它提供了多种方式来读取 Excel 文件。在本文中,我们将介绍使用 OLE 和 Excel Application 读取 Excel 文件的方法。 使用 OLE 读取 Excel 文件 ...

    读取Excel文件中多个sheet

    java读取Excel文件中多个sheet,生成xml格式的文件

    C++读取Excel数据

    在C++中,读取Excel数据通常涉及到使用OLE Automation(对象链接和嵌入自动化)技术,这是一种允许不同应用程序之间交互的方式。在这个特定的例子中,我们使用Microsoft Visual Studio 2003 MFC(Microsoft ...

    java 读取Excel文件中的内容

    在Java编程中,读取Excel文件的内容是一项常见的任务,尤其在数据处理、报表生成或数据分析等领域。Excel文件通常包含表格数据,而Java提供多种库来处理这类任务,比如Apache POI、JExcelApi和OpenCSV等。本篇将重点...

    java写的excel万能工具类

    在这个工具类中,通常会包含一系列静态方法,用于处理各种Excel相关的任务,比如打开文件、读取单元格内容、修改数据、保存文件等。以下是对这个工具类中可能涉及的关键知识点的详细解释: 1. **Apache POI库**:...

    一款很有用的Excel读写工具类

    对于读操作,工具类通常会提供一个接口,允许开发者指定要打开的Excel文件路径和要读取的单元格范围。然后,工具类会解析文件,将读取到的数据以适当的数据类型返回。这样,开发者可以方便地将Excel数据转换为程序中...

    vb6读取excel文件

    以下是一些关于如何在VB6中读取Excel文件及其内容的关键知识点,以及如何连接到SQL数据库以读取数据。 1. **引入对象库**:首先,你需要在VB6项目中引入Microsoft Excel Object Library。这可以通过“工程”菜单 -&gt;...

    qt读取excel文件

    在Qt框架下,读取Excel文件通常涉及到使用第三方库,如QAxContainer模块或QCustomPlot等。QAxContainer允许Qt应用程序与ActiveX控件交互,而Excel文件可以通过Microsoft的COM接口来访问。以下是详细的知识点说明: ...

    CAD动态读取Excel中的内容ReadExcel.rar_CAD读取EXCEL_cad excel_sub_vba cad_v

    清除VBA密码,Private Sub VBAPassword() '你要解保护的Excel文件路径 Filename = Application.GetOpenFilename(&quot;Excel文件(*.xls &amp; *.xla &amp; *.xlt),*.xls;*.xla;*.xlt&quot;, , &quot;VBA破解&quot;)

Global site tag (gtag.js) - Google Analytics