Java实现学生信息管理系统读取Excel数据

news/2024/7/16 7:51:37 标签: spring, ide

场景案例:

假设有一个学生信息管理系统,需要从Excel文件中读取学生的姓名、年龄、成绩等数据,并将这些数据存储到系统中进行进一步的处理和管理。

具体来说,在数据导入/导出系统中调用这个函数,并传入Excel文件作为参数,就可以得到包含学生信息的结果。然后,可以对这个结果进行进一步的处理,比如将学生数据存储到数据库中或进行其他业务逻辑操作。

在Java开发的学生信息管理系统中,读取Excel数据是一个常见的需求。Excel文件常常被用作学生信息的输入源,因此,了解如何使用Java读取Excel数据对于开发人员来说是一项必备技能。本文将详细介绍如何使用Java读取Excel文件,并对异常情况做出处理。

一、环境准备

在开始之前,请确保你已经安装了Java开发环境,并了解基本的Java语法。为了处理Excel文件,我们将使用Apache POI库,它是一个流行的Java库,专门用于处理Microsoft Office文件。如果你还没有安装Apache POI,你可以通过Maven或Gradle将其添加到你的项目中。

二、代码实现

首先,我们需要导入必要的库。在Java中,这通常是通过import语句完成的。然后,我们将创建一个类并定义一个方法来读取Excel文件。

import org.apache.poi.ss.usermodel.*;

import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import java.io.File;

import java.io.FileInputStream;

import java.io.IOException;

import java.util.Iterator;

接下来,我们定义一个名为readExcel的方法,该方法接受一个文件路径作为参数,并返回一个包含所有学生信息的列表。

public List<Student> readExcel(String filePath) {

    List<Student> students = new ArrayList<>();

    try (FileInputStream fis = new FileInputStream(new File(filePath))) {

        Workbook workbook = new XSSFWorkbook(fis);

        Sheet sheet = workbook.getSheetAt(0); // 读取第一个sheet

        Iterator<Row> rowIterator = sheet.iterator(); // 创建一个行迭代器

        while (rowIterator.hasNext()) {

            Row row = rowIterator.next();

            Cell cell = row.getCell(0); // 获取第一列的单元格

            String studentName = cell.getStringCellValue();

            students.add(new Student(studentName));

        }

    } catch (IOException e) {

        e.printStackTrace();

    }

    return students;

}

这个方法首先打开指定的Excel文件,然后读取第一个sheet中的每一行。对于每一行,它获取第一列的单元格,并从中获取学生名。然后,它将这个学生名添加到学生列表中。如果在读取文件或处理数据时发生错误,它将打印错误堆栈跟踪。

三、异常处理

在处理文件和数据时,可能会发生多种错误。例如,文件可能不存在,或者文件可能不是Excel文件。此外,单元格可能不包含我们期望的数据。为了处理这些情况,你应该添加更多的错误检查和处理代码。例如:

  1. 检查文件是否存在:在打开文件之前,可以检查文件是否存在。如果文件不存在,你可以抛出一个异常或返回一个错误消息。

  1. 检查文件是否是Excel文件:在打开文件之前,可以尝试读取文件的几个字节,并检查它们是否是Excel文件的签名(例如,"Poi"对于POI库)。如果不是,你可以抛出一个异常或返回一个错误消息。

  1. 检查单元格的数据类型:如果单元格不包含字符串,那么getStringCellValue方法将抛出一个RuntimeException。你可以使用getCellType方法检查单元格的数据类型,并根据需要处理数据。

4、处理空行:如果sheet中有一行是空的,那么rowIterator.hasNext()将返回false,导致我们停止处理数据。你可以添加一个检查来确保每一行都包含数据。

四、FuncGPT(慧函数)实操

不同的定制化的数据处理需求场景可能有细微的细节差异,按照以上教程从头开始写又太繁琐,这时候开发人员可以想好大致的需求,通过询问FuncGPT(慧函数),依然可以通过使用Apache POI库快速实现Excel文件的读取

输入需求:

读取EXCEL数据,入参: File file,出参:List<Map<String, Object>>

点击生成代码获得完整的代码。

// 类名:ExcelDataReader

// 函数名:readExcelData

// 函数功能:读取Excel数据并返回List<Map<String, Object>>类型的结果

// POM依赖包:

// <dependency>

//     <groupId>org.apache.poi</groupId>

//     <artifactId>poi</artifactId>

//     <version>4.1.2</version>

// </dependency>

// <dependency>

//     <groupId>org.apache.poi</groupId>

//     <artifactId>poi-ooxml</artifactId>

//     <version>4.1.2</version>

// </dependency>

import org.apache.poi.ss.usermodel.*;

import java.io.File;

import java.io.FileInputStream;

import java.io.IOException;

import java.util.ArrayList;

import java.util.HashMap;

import java.util.List;

import java.util.Map;

public class ExcelDataReader {

    /**

     * 读取Excel数据并返回List<Map<String, Object>>类型的结果

     * @param file Excel文件

     * @return Excel数据的List<Map<String, Object>>结果

     * @throws IOException 当读取Excel文件出现错误时抛出IOException

     */

    public static List<Map<String, Object>> readExcelData(File file) throws IOException {

        List<Map<String, Object>> dataList = new ArrayList<>(); // 创建存储Excel数据的List

        FileInputStream fis = new FileInputStream(file); // 创建文件输入流

        Workbook workbook = WorkbookFactory.create(fis); // 创建Workbook对象

        Sheet sheet = workbook.getSheetAt(0); // 获取第一个Sheet

        int rowCount = sheet.getLastRowNum(); // 获取行数

        Row headerRow = sheet.getRow(0); // 获取标题行

        int columnCount = headerRow.getLastCellNum(); // 获取列数

        for (int i = 1; i <= rowCount; i++) { // 遍历每一行(跳过标题行)

            Row row = sheet.getRow(i);

            Map<String, Object> rowData = new HashMap<>();

            for (int j = 0; j < columnCount; j++) { // 遍历每一列

                Cell cell = row.getCell(j);

                String columnName = headerRow.getCell(j).getStringCellValue(); // 获取列名

                Object cellValue;

                switch (cell.getCellType()) { // 根据单元格类型获取单元格值

                    case STRING:

                        cellValue = cell.getStringCellValue();

                        break;

                    case NUMERIC:

                        cellValue = cell.getNumericCellValue();

                        break;

                    case BOOLEAN:

                        cellValue = cell.getBooleanCellValue();

                        break;

                    case FORMULA:

                        cellValue = cell.getCellFormula();

                        break;

                    default:

                        cellValue = null;

                }

                rowData.put(columnName, cellValue); // 将列名和单元格值存入rowData

            }

            dataList.add(rowData); // 将rowData存入dataList

        }

        workbook.close(); // 关闭Workbook对象

        fis.close(); // 关闭文件输入流

        return dataList; // 返回Excel数据的结果

    }

}

// 函数示例

// 读取Excel数据示例

// 入参:file,Excel文件

// 出参:dataList,Excel数据的List<Map<String, Object>>结果

// 调用示例:

// File file = new File("data.xlsx");

// List<Map<String, Object>> dataList = ExcelDataReader.readExcelData(file);

// System.out.println(dataList);

// 输出结果:例如,Excel数据为:

// | Name  | Age | Grade |

// |-------|-----|-------|

// | Alice | 18  | A     |

// | Bob   | 20  | B     |

// 则输出结果为:[{Name=Alice, Age=18, Grade=A}, {Name=Bob, Age=20, Grade=B}]

// 表示Excel数据被封装为List<Map<String, Object>>的格式

FuncGPT(慧函数)就像一个线上的“名师”,可以在短时间内根据你的需求给到一个清晰易懂,可读性优秀,相对精准的“解决方案”,甚至是拿来即用的代码。而在特定的需求场景下,开发人员可以根据自己的实际需求在FuncGPT(慧函数)生成的代码基础上进行修改。

比如,由于EXCEL整体格式内容的话,会影响读取有效行或者有效列的真实数据,故需要对行和列进行相关有效校验。在原有代码的基础上,可以做以下一些修改:

1)首先判断列,因为列的真实长度会影响到行的读取;

2)读取第一行表头,如果遇到空白列,则认定有效列为上一个列的下标。

3)获取到有效列之后 去遍历每一行数数据,如果有整行为空则跳出循环,结束数据获取。

FuncGPT(慧函数)现已免费开放,下载链接:Java全自动开发工具: 新一代Java开发工具 | 可视化编辑 | 测试运维自动化

五、总结

通过以上代码和解释,我们了解了如何使用Java和Apache POI库来读取Excel文件。这对于开发学生信息管理系统等应用非常重要。同时,对可能出现的异常进行适当的处理也是开发过程中不可或缺的一部分。希望这篇文章能帮助你实现你的项目。


http://www.niftyadmin.cn/n/4985412.html

相关文章

Jack Daniels经典跑步训练法(原书第三版)总结

Jack Daniels经典跑步训练法总结 CH1基本法则天资内部动机机遇指导补充法则 CH2 如何训练原则步频跑步时的呼吸 CH3 关注自己的体能VO 2 _2 2​max,VODT,vVO 2 _2 2​max和跑步效率的概念跑步变量和改善跑步中的心率相对VO 2 _2 2​ CH4 选择恰当的训练类型&#xff08;E、M、T…

PANAMA: 共享机器学习集群的网内聚合框架

随着深度学习训练规模的增长&#xff0c;在共享集群内同步训练数据的需求越来越多&#xff0c;怎样高效利用网络资源平衡各种负载的需求&#xff0c;也成了业界关注的课题。MIT的这篇论文提出了一种网内聚合框架&#xff0c;能够大幅降低并行数据作业的流量负载&#xff0c;从而…

【ES】笔记-Set集合实践

JS <script>let arr[1,2,3,4,5,4,3,2,1];//1.数组去重let result0[...new Set(arr)];console.log(数组去重${result0});//2.交集let arr2[4,5,6,5,6];let result[...new Set(arr)].filter(item>{let s2new Set(arr2);//4 5 6if(s2.has(item)){return true;}else{retur…

架构师成长之路Redis第二篇|Redis配置文件参数讲解

Redis.conf文件 官网Redis文档链接:Redis官网 官网Redis config配置文件参数讲解:https://redis.io/docs/management/config/ Redis.conf参考模板例子 : https://redis.io/docs/management/config-file/ Redis 可以使用内置的默认配置在没有配置文件的情况下启动,但是仅…

遇到 Binder这些面试题,你会怎么答?

作为开发人员&#xff0c;每个人都有每个人擅长领域&#xff0c;自然也有自己不擅长的领域&#xff0c;很难成为完美的一个全栈开发。在面试中最怕遇见的一件事是面试官专挑你不擅长的领域进行提问&#xff0c;目的就是看你遇到问题的应变能力。 接下给大家分享一个面试中容易被…

Python Matplotlib小技巧!

本文介绍Python Matplotlib实用小技巧&#xff01; 1. 添加标题-title matplotlib.pyplot 对象中有个 title() 可以设置表格的标题。 **import** numpy **as** np **import** matplotlib.pyplot **as** plt \# 显示中文 plt.rcParams\[font.sans-serif\] \[uSimHei\] …

企业微信cgi-bin/gateway/agentinfo接口存在未授权访问漏洞 附POC

文章目录 企业微信cgi-bin/gateway/agentinfo接口存在未授权访问漏洞 附POC1. 企业微信cgi-bin/gateway/agentinfo接口简介2.漏洞描述3.影响版本4.fofa查询语句5.漏洞复现6.POC&EXP7.整改意见8.往期回顾 企业微信cgi-bin/gateway/agentinfo接口存在未授权访问漏洞 附POC 免…

【DRONECAN】(三)WSL2 及 ubuntu20.04 CAN 驱动安装

【DRONECAN】&#xff08;三&#xff09;WSL2 及 ubuntu20.04 CAN 驱动安装 前言 这一篇文章主要介绍一下 WSL2 及 ubuntu20.04 CAN 驱动的安装&#xff0c;首先说一下介绍本文的目的。 大家肯定都接触过 ubuntu 系统&#xff0c;但是我们常用的操作系统都是 Windows&#x…