首页 > 编程语言 >Java实现学生信息管理系统:从Excel中提取数据的实用方法

Java实现学生信息管理系统:从Excel中提取数据的实用方法

时间:2024-02-01 17:32:37浏览次数:21  
标签:文件 Java 读取 List Excel 信息管理系统 数据

在Java中实现学生信息管理系统并从Excel中读取数据,通常适用于以下场景: 数据迁移和集成:如果你有一个现存的学生信息管理系统,该系统可能使用数据库或其他存储方式,但你想将这些数据迁移到新的系统。Excel文件可能提供了一种方便的方式来迁移这些数据,因为Excel文件格式易于查看和编辑。 数据导入:如果你正在开发一个新的学生信息管理系统,你可能需要从其他来源导入学生信息。Excel文件可能是一个易于获取和使用的格式,特别是当这些数据已经在Excel文件中时。 数据分析:如果你需要对学生信息进行统计分析或可视化,Excel文件可能是一个很好的起点。你可以使用Java程序读取Excel文件,然后对这些数据进行处理和分析。 简化数据输入:在某些情况下,学生或教职工可能更愿意使用Excel表格来输入数据,而不是通过一个复杂的在线表单或界面。Java程序可以读取这些Excel文件并将其导入到数据库或系统中。 与其他系统的集成:如果有一个外部系统或服务(例如财务系统或学生成绩服务)已经使用了Excel格式的数据,那么Java程序可以通过读取这些Excel文件来集成这些数据。 备份和恢复:在某些情况下,将数据导出到Excel文件可能是一种方便的备份策略。同样,如果系统出现故障或数据丢失,可以从这些Excel文件中恢复数据。 本文将详细介绍如何使用Java读取Excel文件,并对异常情况做出处理。 一、环境准备 在开始之前,请确保你已经安装了Java开发环境,并了解基本的Java语法。为了处理Excel文件,我们将使用Apache POI库,它是一个流行的Java库,专门用于处理Microsoft Office文件。如果你还没有安装Apache POI,你可以通过Maven或Gradle将其添加到你的项目中。 二、代码实现 通过询问FuncGPT(慧函数),依然可以通过使用Apache POI库快速实现Excel文件的读取。 输入需求: 读取EXCEL数据,入参: File file,出参:List<Map<String, Object>> 点击生成代码获得完整的代码。

// 函数名: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>>的格式

三、异常处理 在处理文件和数据时,可能会发生多种错误。例如,文件可能不存在,或者文件可能不是Excel文件。此外,单元格可能不包含我们期望的数据。为了处理这些情况,应该添加更多的错误检查和处理代码。例如: 1、 检查文件是否存在:在打开文件之前,可以检查文件是否存在。如果文件不存在,你可以抛出一个异常或返回一个错误消息。 2、 检查文件是否是Excel文件:在打开文件之前,可以尝试读取文件的几个字节,并检查它们是否是Excel文件的签名(例如,"Poi"对于POI库)。如果不是,你可以抛出一个异常或返回一个错误消息。 3、 检查单元格的数据类型:如果单元格不包含字符串,那么getStringCellValue方法将抛出一个RuntimeException。你可以使用getCellType方法检查单元格的数据类型,并根据需要处理数据。 4、处理空行:如果sheet中有一行是空的,那么rowIterator.hasNext()将返回false,导致我们停止处理数据。你可以添加一个检查来确保每一行都包含数据。 FuncGPT(慧函数)就像一个线上的“名师”,可以在短时间内根据你的需求给到一个清晰易懂,可读性优秀,相对精准的“解决方案”,甚至是拿来即用的代码。而在特定的需求场景下,开发人员可以根据自己的实际需求在FuncGPT(慧函数)生成的代码基础上进行修改。 通过以上代码和解释,我们了解了如何使用Java和Apache POI库来读取Excel文件。这对于开发学生信息管理系统等应用非常重要。同时,对可能出现的异常进行适当的处理也是开发过程中不可或缺的一部分。

标签:文件,Java,读取,List,Excel,信息管理系统,数据
From: https://blog.51cto.com/u_15327851/9534659

相关文章

  • Java 框架
    框架是整个或者部分系统的可重用设计,从应用角度看框架,可以被当作一组抽象构建及构件实例间交互的方法;从应用目的的角度看,SpringSpring定义Spring通常指的是SpringFramework,它是一个开源框架。Spring是包含众多工具方法的IoC容器。什么是容器容器时用来容纳某种物品的基......
  • Java面向对象程序设计——带异常处理的person类
    带异常处理的person类【问题描述】定义一个Person类,属性包含姓名、年龄。方法:无参构造方法、有参构造方法、getter和setter方法、toString方法。其中:setter方法在设置年龄的时候,要求对年龄进行参数的正确性检测,年龄有效范围在1-100之间,否则抛出IllegalArgumentException异常【输......
  • Java并发基础:CyclicBarrier全面解析!
    内容摘要CyclicBarrier的优点在于实现了线程间的相互等待与协同,确保所有线程在达到预定屏障点后才能继续执行,它支持屏障的重复使用,非常适合多轮次的任务同步,此外,CyclicBarrier还允许在屏障点执行特定操作,为复杂的多线程协作提供了便利。核心概念业务场景CyclicBarrier允许一组......
  • excel学习记录
    《相关案例详见博客园文件》1.记录整理、数据计算、数据分析、数据展现2.保存->工具->常规选项->设置打开密码和修改权限密码,修改权限密码表示可以修改,但是修改后不能保存3.快速填充ctrl+e:对数据拆分、重组、合并 例如:A列有邮箱数据,想提取出邮箱数据中的人名,在B列输入A1中的......
  • EasyExcel 读取单元格内图片
    EasyExcel读取单元格内图片1.需求介绍需要实现Excel数据批量导入,且Excel中某个单元格内存在图片,需要将图片解析上传,并与所在行数据进行绑定,具体数据如:2.具体实现2.1版本介绍easyexcel:3.3.2SpringBoot:2.7.1hutool:5.7.212.2解决思路参考hutoolExcelPicUtil工具类,通......
  • java学习02
    可以用_和字母和$作为标识符开头,特殊字符不能出现在名字中、float和long类型要在赋值后面加上大写首字母最好避免使用浮点数进行比较,因为浮点数是离散的数,接近但不等于使用时会出问题char字符本质都是数字,通过int类型转换可以知道/u0000可以输出起点/uffff是char终点使用下......
  • Java和JavaScript区别与联系
    JavaScript和java属于两门语言。参考了java语言,“看上去与Java足够相似,但是比Java简单”,是简化版Java语言。特别是在定义对象变量的时候,省略的太极端了。java里有的很多常用类型的对象在js中是没有的。JavaScript由原网景(Netscape)公司的高级工程师布兰登·艾奇(BrendanEich)(曾经的M......
  • 在Java中重写hashCode()方法
    而在重写equals()方法时,总要重写hashCode()方法,原因总结下有以下两点:1.使用hashcode方法提前校验,可以避免每一次比对都调用equals方法,提高效率2.保证是同一个对象,如果重写了equals方法,而没有重写hashcode方法,会出现equals相等的对象,hashcode不相等的情况,重写hashcode方法就是为了......
  • 深入浅出Java多线程(五):线程间通信
    引言大家好,我是你们的老伙计秀才!今天带来的是[深入浅出Java多线程]系列的第五篇内容:线程间通信。大家觉得有用请点赞,喜欢请关注!秀才在此谢过大家了!!!在现代编程实践中,多线程技术是提高程序并发性能、优化系统资源利用率的关键手段。Java作为主流的多线程支持语言,不仅提供了丰富的......
  • js处理excel数据
    借助xlsx实现js读取处理excel数据,并输出excel文件<inputtype="file"@change="fn"/>import*asXLSXfrom'xlsx'fn(e){letfileObj=e.target.files[0]constfileReader=newFileReader()fileReader.readAsArrayBuffer(fileObj)fileR......