如何在 Java 中将 Excel 数据转换为 ArrayList?

简介: 【8月更文挑战第23天】

在 Java 编程中,处理 Excel 文件是一个常见的需求,尤其是在数据分析和报告生成中。ArrayList 是 Java 集合框架中的一个动态数组,它可以灵活地增长和缩减。在实际应用中,我们经常需要从 Excel 文件中读取数据并将其存储到 ArrayList 中。本文将详细介绍如何使用 Java 在 Excel 中创建 ArrayList

概述

要将 Excel 数据转换为 ArrayList,我们需要使用一个可以读取 Excel 文件的库。Apache POI 是一个非常流行的 Java 库,它允许我们处理 Microsoft Office 文档,包括 Excel。在本文中,我们将使用 Apache POI 来读取 Excel 文件,并将数据存储到 ArrayList 中。

环境准备

首先,你需要在你的项目中引入 Apache POI 库。如果你使用 Maven,你可以在 pom.xml 文件中添加以下依赖:

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>5.2.3</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>5.2.3</version>
</dependency>

读取 Excel 文件

接下来,我们将编写 Java 代码来读取 Excel 文件。我们将使用 XSSFWorkbook 类来读取 .xlsx 格式的文件,并将每个单元格的数据存储到 ArrayList 中。

示例代码
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import java.io.File;
import java.io.FileInputStream;
import java.util.ArrayList;
import java.util.List;

public class ExcelToArrayList {
   
    public static void main(String[] args) {
   
        try {
   
            FileInputStream file = new FileInputStream(new File("example.xlsx"));
            Workbook workbook = new XSSFWorkbook(file);
            Sheet sheet = workbook.getSheetAt(0);

            List<List<String>> arrayList = new ArrayList<>();

            for (Row row : sheet) {
   
                List<String> rowData = new ArrayList<>();
                for (Cell cell : row) {
   
                    rowData.add(cell.toString());
                }
                arrayList.add(rowData);
            }

            workbook.close();
            file.close();

            System.out.println(arrayList);
        } catch (Exception e) {
   
            e.printStackTrace();
        }
    }
}

在这个例子中,我们首先打开一个名为 "example.xlsx" 的 Excel 文件,并获取第一个工作表。然后,我们遍历工作表中的每一行,对于每一行,我们创建一个 ArrayList 来存储该行的单元格数据。最后,我们将这些行数据添加到总的 ArrayList 中。

总结

在 Java 中将 Excel 数据转换为 ArrayList 可以使用 Apache POI 库来实现。通过读取 Excel 文件中的工作表、行和单元格,我们可以将数据存储到 ArrayList 中,以便进一步处理或分析。理解这个过程可以帮助我们更有效地处理 Excel 数据,并在 Java 应用程序中利用这些数据。

目录
相关文章
|
10月前
|
Java API 开发工具
【Azure Developer】Java代码实现获取Azure 资源的指标数据却报错 "invalid time interval input"
在使用 Java 调用虚拟机 API 获取指标数据时,因本地时区设置非 UTC,导致时间格式解析错误。解决方法是在代码中手动指定时区为 UTC,使用 `ZoneOffset.ofHours(0)` 并结合 `withOffsetSameInstant` 方法进行时区转换,从而避免因时区差异引发的时间格式问题。
414 4
|
11月前
|
数据采集 JSON Java
Java爬虫获取1688店铺所有商品接口数据实战指南
本文介绍如何使用Java爬虫技术高效获取1688店铺商品信息,涵盖环境搭建、API调用、签名生成及数据抓取全流程,并附完整代码示例,助力市场分析与选品决策。
|
12月前
|
Python
如何根据Excel某列数据为依据分成一个新的工作表
在处理Excel数据时,我们常需要根据列值将数据分到不同的工作表或文件中。本文通过Python和VBA两种方法实现该操作:使用Python的`pandas`库按年级拆分为多个文件,再通过VBA宏按班级生成新的工作表,帮助高效整理复杂数据。
|
11月前
|
数据采集 存储 前端开发
Java爬虫性能优化:多线程抓取JSP动态数据实践
Java爬虫性能优化:多线程抓取JSP动态数据实践
|
12月前
|
数据采集 数据可视化 数据挖掘
用 Excel+Power Query 做电商数据分析:从 “每天加班整理数据” 到 “一键生成报表” 的配置教程
在电商运营中,数据是增长的关键驱动力。然而,传统的手工数据处理方式效率低下,耗费大量时间且易出错。本文介绍如何利用 Excel 中的 Power Query 工具,自动化完成电商数据的采集、清洗与分析,大幅提升数据处理效率。通过某美妆电商的实战案例,详细拆解从多平台数据整合到可视化报表生成的全流程,帮助电商从业者摆脱繁琐操作,聚焦业务增长,实现数据驱动的高效运营。
|
人工智能 安全 JavaScript
Java ArrayList:动态数组
本文探讨Java中的数组,对比C/C++、JS/PHP/Python等语言的数组特性。文章分析了Java数组的定义、创建方式及其规范,指出其优缺点。Java数组作为引用类型,在堆上分配内存,支持动态大小,避免了C/C++中裸数组的常见问题(如越界访问)。然而,Java数组也存在性能瓶颈和设计缺陷,例如运行时的安全检查影响速度,无法创建超大数组或泛型数组,且多线程场景下缺乏同步机制。作者建议在实际开发中用集合替代数组以规避这些问题。
334 1
|
存储 安全 大数据
网安工程师必看!AiPy解决fscan扫描数据整理难题—多种信息快速分拣+Excel结构化存储方案
作为一名安全测试工程师,分析fscan扫描结果曾是繁琐的手动活:从海量日志中提取开放端口、漏洞信息和主机数据,耗时又易错。但现在,借助AiPy开发的GUI解析工具,只需喝杯奶茶的时间,即可将[PORT]、[SERVICE]、[VULN]、[HOST]等关键信息智能分类,并生成三份清晰的Excel报表。告别手动整理,大幅提升效率!在安全行业,工具党正碾压手动党。掌握AiPy,把时间留给真正的攻防实战!官网链接:https://www.aipyaipy.com,解锁更多用法!
|
9月前
|
存储 Java 索引
用Java语言实现一个自定义的ArrayList类
自定义MyArrayList类模拟Java ArrayList核心功能,支持泛型、动态扩容(1.5倍)、增删改查及越界检查,底层用Object数组实现,适合学习动态数组原理。
380 4
|
自然语言处理 Java 关系型数据库
Java|小数据量场景的模糊搜索体验优化
在小数据量场景下,如何优化模糊搜索体验?本文分享一个简单实用的方案,虽然有点“土”,但效果还不错。
372 0
|
10月前
|
算法 Java
Java多线程编程:实现线程间数据共享机制
以上就是Java中几种主要处理多线程序列化资源以及协调各自独立运行但需相互配合以完成任务threads 的技术手段与策略。正确应用上述技术将大大增强你程序稳定性与效率同时也降低bug出现率因此深刻理解每项技术背后理论至关重要.
595 16

热门文章

最新文章