Java解析Excel

Excel作为一种常用的数据处理工具,在开发过程中也扮演着重要的角色。Java作为一种广泛使用的编程语言,也提供了许多解析Excel的库。本文将从多个方面对Java解析Excel做详细的阐述。

一、使用POI库解析Excel

Apache POI是一种开源的Java API,用于处理微软的DOC、XLS、PPT等文件。许多Java开发人员使用Apache POI来解析和创建Excel文件。POI库提供了两个不同的API来解析Excel文件。分别是:HSSFXSSF

1、HSSF

HSSF是POI库的一个重要部分,用于解析Excel 97-2003文件格式的文件,也称作“xls”格式。以下是一个基本的HSSF读取示例:

FileInputStream inputStream = new FileInputStream(new File("C:\\temp\\test.xls"));
HSSFWorkbook workbook = new HSSFWorkbook(inputStream);
HSSFSheet sheet = workbook.getSheetAt(0);
Iterator<Row> iterator = sheet.iterator();
while (iterator.hasNext()) {
    Row currentRow = iterator.next();
    Iterator<Cell> cellIterator = currentRow.iterator();
    while (cellIterator.hasNext()) {
        Cell currentCell = cellIterator.next();
        if (currentCell.getCellType() == CellType.STRING) {
            System.out.print(currentCell.getStringCellValue() + "--");
        } else if (currentCell.getCellType() == CellType.NUMERIC) {
            System.out.print(currentCell.getNumericCellValue() + "--");
        }
    }
    System.out.println();
}
workbook.close();
inputStream.close();

2、XSSF

XSSF是POI库的另一个部分,用于解析Excel 2007或更高版本的文件格式,也称作“xlsx”格式。以下是一个基本的XSSF读取示例:

FileInputStream inputStream = new FileInputStream(new File("C:\\temp\\test.xlsx"));
XSSFWorkbook workbook = new XSSFWorkbook(inputStream);
XSSFSheet sheet = workbook.getSheetAt(0);
Iterator<Row> iterator = sheet.iterator();
while (iterator.hasNext()) {
    Row currentRow = iterator.next();
    Iterator<Cell> cellIterator = currentRow.iterator();
    while (cellIterator.hasNext()) {
        Cell currentCell = cellIterator.next();
        if (currentCell.getCellType() == CellType.STRING) {
            System.out.print(currentCell.getStringCellValue() + "--");
        } else if (currentCell.getCellType() == CellType.NUMERIC) {
            System.out.print(currentCell.getNumericCellValue() + "--");
        }
    }
    System.out.println();
}
workbook.close();
inputStream.close();

二、使用JExcelApi库解析Excel

JExcelApi是一种流行的Java API,用于处理Excel文件格式。它与POI库类似,但用法略有不同。

1、读取Excel文件

以下是一个基本的JExcelApi读取Excel文件的示例:

WorkbookSettings ws = new WorkbookSettings();
ws.setLocale(new Locale("en", "EN"));
Workbook workbook = Workbook.getWorkbook(new File("C:\\temp\\test.xls"), ws);
Sheet sheet = workbook.getSheet(0);
for (int i = 0; i < sheet.getRows(); i++) {
    for (int j = 0; j < sheet.getColumns(); j++) {
        Cell cell = sheet.getCell(j, i);
        System.out.print(cell.getContents() + "--");
    }
    System.out.println();
}
workbook.close();

2、写入Excel文件

以下是一个基本的JExcelApi写入Excel文件的示例:

WritableWorkbook workbook = Workbook.createWorkbook(new File("C:\\temp\\output.xls"));
WritableSheet sheet = workbook.createSheet("Sheet1", 0);
Label label = new Label(0, 0, "Label test");
sheet.addCell(label);
Number number = new Number(1, 0, 123.45);
sheet.addCell(number);
workbook.write();
workbook.close();

三、使用EasyExcel库解析Excel

EasyExcel是一种比较新的Java库,其目的是让Java处理Excel具有更高的可读性、更好的性能和更好的易用性。EasyExcel支持读取、写入、处理大型Excel文件等功能,具有良好的兼容性和可扩展性。

1、读取Excel文件

EasyExcel读取Excel文件的示例如下:

String fileName = "C:\\temp\\test.xlsx";
EasyExcel.read(fileName, new AnalysisEventListener<DemoData>() {
    @Override
    public void invoke(DemoData demoData, AnalysisContext analysisContext) {
        System.out.println(demoData);
    }
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {}
}).sheet().doRead();

2、写入Excel文件

EasyExcel写入Excel文件的示例如下:

String fileName = "C:\\temp\\output.xlsx";
EasyExcel.write(fileName, DemoData.class).sheet("Sheet1").doWrite(dataList);

其中,DemoData是用户自定义的Java对象,表示Excel文件中的一个表格。

四、使用Java Spreadsheet API解析Excel

Java Spreadsheet API是一种很新的Java库,用于处理Microsoft Excel文件格式。它提供了一种API,使Java开发人员可以轻松地读取和写入Excel文件。

1、读取Excel文件

以下是一个Java Spreadsheet API读取Excel文件的示例:

SpreadsheetInfo.setLicense("FREE-LIMITED-KEY");
FileInputStream inputStream = new FileInputStream(new File("C:\\temp\\test.xlsx"));
SpreadsheetDocument document = SpreadsheetDocument.load(inputStream);
Worksheet sheet = document.getWorksheets().get(0);
for (int i = 0; i < sheet.getCells().getRows().getCount(); i++) {
    for (int j = 0; j < sheet.getCells().getColumns().getCount(); j++) {
        Cell cell = sheet.getCells().get(i, j);
        System.out.print(cell.getValue() + "--");
    }
    System.out.println();
}
document.close();
inputStream.close();

2、写入Excel文件

以下是一个Java Spreadsheet API写入Excel文件的示例:

SpreadsheetInfo.setLicense("FREE-LIMITED-KEY");
SpreadsheetDocument document = new SpreadsheetDocument();
Worksheet sheet = document.getWorksheets().add("Sheet1");
sheet.getCells().get("A1").setValue("Label test");
sheet.getCells().get("B1").setValue(123.45);
document.save("C:\\temp\\output.xlsx");
document.close();

五、使用JXL解析Excel

JXL是另一种广泛使用的Java库,用于处理Excel文件格式。虽然JXL比POI和JExcelApi都要早,但它仍然被许多Java开发人员广泛使用。

1、读取Excel文件

以下是一个基本的JXL读取Excel文件的示例:

Workbook workbook = Workbook.getWorkbook(new File("C:\\temp\\test.xls"));
Sheet sheet = workbook.getSheet(0);
for (int i = 0; i < sheet.getRows(); i++) {
    for (int j = 0; j < sheet.getColumns(); j++) {
        Cell cell = sheet.getCell(j, i);
        System.out.print(cell.getContents() + "--");
    }
    System.out.println();
}
workbook.close();

2、写入Excel文件

以下是一个基本的JXL写入Excel文件的示例:

WritableWorkbook workbook = Workbook.createWorkbook(new File("C:\\temp\\output.xls"));
WritableSheet sheet = workbook.createSheet("Sheet1", 0);
Label label = new Label(0, 0, "Label test");
sheet.addCell(label);
Number number = new Number(1, 0, 123.45);
sheet.addCell(number);
workbook.write();
workbook.close();

六、小结

本文详细介绍了Java解析Excel的几种流行的库,包括POI、JExcelApi、EasyExcel、Java Spreadsheet API和JXL。每个库都提供了读取和/或写入Excel文件的功能,并且具有各自的优点和不同的用法。开发人员可以根据自己的具体需求选择一个或多个库。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/185404.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝的头像小蓝
上一篇 2024-11-26 12:19
下一篇 2024-11-26 12:19

相关推荐

  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • java client.getacsresponse 编译报错解决方法

    java client.getacsresponse 编译报错是Java编程过程中常见的错误,常见的原因是代码的语法错误、类库依赖问题和编译环境的配置问题。下面将从多个方面进行分析…

    编程 2025-04-29
  • Java Bean加载过程

    Java Bean加载过程涉及到类加载器、反射机制和Java虚拟机的执行过程。在本文中,将从这三个方面详细阐述Java Bean加载的过程。 一、类加载器 类加载器是Java虚拟机…

    编程 2025-04-29
  • Java腾讯云音视频对接

    本文旨在从多个方面详细阐述Java腾讯云音视频对接,提供完整的代码示例。 一、腾讯云音视频介绍 腾讯云音视频服务(Cloud Tencent Real-Time Communica…

    编程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介绍

    本文将详细介绍Java Milvus SearchParam withoutFields的相关知识和用法。 一、什么是Java Milvus SearchParam without…

    编程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java语言中的一个版本,于2014年3月18日发布。本文将从多个方面对Java 8中某一周的周一进行详细的阐述。 一、数组处理 Java 8新特性之一是Stream…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29
  • VSCode为什么无法运行Java

    解答:VSCode无法运行Java是因为默认情况下,VSCode并没有集成Java运行环境,需要手动添加Java运行环境或安装相关插件才能实现Java代码的编写、调试和运行。 一、…

    编程 2025-04-29
  • Java任务下发回滚系统的设计与实现

    本文将介绍一个Java任务下发回滚系统的设计与实现。该系统可以用于执行复杂的任务,包括可回滚的任务,及时恢复任务失败前的状态。系统使用Java语言进行开发,可以支持多种类型的任务。…

    编程 2025-04-29
  • Java 8 Group By 会影响排序吗?

    是的,Java 8中的Group By会对排序产生影响。本文将从多个方面探讨Group By对排序的影响。 一、Group By的概述 Group By是SQL中的一种常见操作,它…

    编程 2025-04-29

发表回复

登录后才能评论