网站首页 > java教程 正文
在企业级项目开发中,要经常涉及excel文件和程序之间导入导出的业务要求,那么今天来讲一讲excel文件导入的实现。java实现对excel的操作有很多种方式,例如EasyExcel等,今天我们使用的是POI技术实现excel文件的导入。
POI技术简介
1.POI概念
Apache POI 是用Java编写的免费开源的跨平台的Java API,Apache POI提供API给Java程序对Microsoft Office格式档案读和写的功能,其中使用最多的就是使用POI操作Excel文件。POI为“Poor Obfuscation Implementation”的首字母缩写,意为“简洁版的模糊实现”。
官网地址:
https://poi.apache.org/components/index.html
2.POI坐标依赖
3.POI核心API概述
3.1 创建工作簿对象
3.2 获取execl表中的sheet对象
3.3 获取excel文件中所有物理数据的有效行数
3.4 获取行对象
3.5 获取行中的列对象
3.6 获取列的字符串类型数据
3.7 获取列的数字类型字段数据
POI技术使用
1.需求分析
从一个准备好的Excel表格文件中读取学生信息,然后将学生的信息通过POI技术导入到数据库的学生表中。
2.实现思路
以下是具体的实现思路:
- 准备excel文件,里面存储若干学生信息:包含学生姓名、年龄和手机号;
- 创建web项目,导入相关jar依赖;
- 创建数据库并创建一张学生表;
- 使用POI读取文件的学生信息;
- 将获取到的学生信息封装到学生对象;
- 通过JDBC技术将学生信息保存到学生表。
3.案例实现
3.1 准备学生信息的excel文件
我们先创建一个student.xlsx文件
3.2 创建web项目,导入jar依赖
pom.xml核心依赖如下:
3.3 创建数据库并创建一张学生表
3.4 创建Student实体类
3.5 创建StudentServlet
3.6 创建StudentService
3.7 创建StudentDao
4.效果图示例
首页效果如下图:
导入成功提示:
导入成功后学生表:
至此,我们就实现了POI导入excel文件的操作,当然还有一些更复杂的操作在这里没有展开,例如导入excel中的部分行、部分列的数据,以及导出数据到excel等操作。
猜你喜欢
- 2024-11-17 「开源资讯」MyExcel 3.3.0.GA 发布,终于支持图片导入啦
- 2024-11-17 EasyExcel 优雅实现 Excel 导入导出
- 2024-11-17 Spring Boot框架下实现Excel服务端导入导出
- 2024-11-17 Java 设置Excel工作表的视图模式
- 2024-11-17 使用jxl将excel行转列输出
- 2024-11-17 在Java中,如何以编程的方式设置 Excel 单元格样式
- 2024-11-17 Java 将Excel工作表中的图表转换为图片
- 2024-11-17 Java 查找、替换并高亮Excel数据
- 2024-11-17 相见恨晚,用阿里 EasyExcel 优雅实现导入导出功能
- 2024-11-17 Java实现文件批量导入导出实践(兼容xls,xlsx)
你 发表评论:
欢迎- 最近发表
-
- 你真的会用 Java 中的线程池吗?多个企业级线程池工具类封装实践
- 线程池的实现原理、优点与风险、以及四种线程池实现
- Java线程池ThreadPoolExecutor实现原理剖析
- 深入分析线程池的实现原理(线程池是干嘛的)
- 一文搞懂JAVA线程池工作原理(java线程池的工作流程)
- Java线程池的工作原理(java线程池的实现原理)
- 5分钟读懂C#中TcpClient、TcpListener和Socket三个类的角色
- JVM对象的创建过程(jvm运行过程中创建的对象一般存放在方法区)
- 对象组成与Java内存模型JMM分析(java对象在内存中存储的结构)
- JVM对象内存分配详细过程(栈上分配->TLAB->老年代->Eden区)
- 标签列表
-
- java反编译工具 (77)
- java反射 (57)
- java接口 (61)
- java随机数 (63)
- java7下载 (59)
- java数据结构 (61)
- java 三目运算符 (65)
- java对象转map (63)
- Java继承 (69)
- java字符串替换 (60)
- 快速排序java (59)
- java并发编程 (58)
- java api文档 (60)
- centos安装java (57)
- java调用webservice接口 (61)
- java深拷贝 (61)
- 工厂模式java (59)
- java代理模式 (59)
- java.lang (57)
- java连接mysql数据库 (67)
- java重载 (68)
- java 循环语句 (66)
- java反序列化 (58)
- java时间函数 (60)
- java是值传递还是引用传递 (62)
本文暂时没有评论,来添加一个吧(●'◡'●)