千锋教育-做有情怀、有良心、有品质的职业教育机构

当前位置:首页  >  关于学院  >  技术干货  >  Java技术干货  >  正文

POI技术实现excel文件的导入

来源:千锋教育
作者:qyf
关键词: poi 学生
2023-03-23
分享

  在企业级项目开发中,要经常涉及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坐标依赖

  org.apache.poipoi-ooxml4.1.2

  3.POI核心API概述

  3.1 创建工作簿对象

  Workbook workbook=new XSSFWorkbook(path)

  3.2 获取execl表中的sheet对象

  Sheet sheet = workbook.getSheetAt(0);

  3.3 获取excel文件中所有物理数据的有效行数

  int rows = sheet.getPhysicalNumberOfRows()

  3.4 获取行对象

  Row row =sheet.getRow(i)

  3.5 获取行中的列对象

  Cell cell=row.getCell(0)

  3.6 获取列的字符串类型数据

  cell.getStringCellValue()

  3.7 获取列的数字类型字段数据

  cell.getNumericCellValue()

  POI技术使用

  1.需求分析

  从一个准备好的Excel表格文件中读取学生信息,然后将学生的信息通过POI技术导入到数据库的学生表中。

  2.实现思路

  以下是具体的实现思路:

  准备excel文件,里面存储若干学生信息:包含学生姓名、年龄和手机号;

  创建web项目,导入相关jar依赖;

  创建数据库并创建一张学生表;

  使用POI读取文件的学生信息;

  将获取到的学生信息封装到学生对象;

  通过JDBC技术将学生信息保存到学生表。

  3.案例实现

  3.1 准备学生信息的excel文件

  我们先创建一个student.xlsx文件。

图片 1

  3.2 创建web项目,导入jar依赖

图片 2

  pom.xml核心依赖如下:

   org.apache.poi poi-ooxml 4.1.2 javax.servlet javax.servlet-api 4.0.1 provided mysql mysql-connector-java 5.1.6 com.mchange c3p0 0.9.5commons-dbutilscommons-dbutils1.7

  3.3 创建数据库并创建一张学生表

  #创建学生数据库CREATE DATABASE studb;#创建学生表CREATE TABLE `student` ( `id` INT(11) NOT NULL AUTO_INCREMENT, `sname` VARCHAR(30) DEFAULT NULL, `age` INT(11) DEFAULT NULL, `phone` VARCHAR(20) DEFAULT NULL, PRIMARY KEY (`id`))

  3.4 创建Student实体类

  package com.qf.pojo;public class Student { private Integer id; private String sname; private Integer age; private String phone; public Student(String sname, Integer age, String phone) { this.sname = sname; this.age = age; this.phone = phone; } public Student(Integer id, String sname, Integer age, String phone) { this.id = id; this.sname = sname; this.age = age; this.phone = phone; } public Student() { } public Integer getId() { return id; } public void setId(Integer id) { this.id = id; } public String getSname() { return sname; } public void setSname(String sname) { this.sname = sname; } public Integer getAge() { return age; } public void setAge(Integer age) { this.age = age; } public String getPhone() { return phone; } public void setPhone(String phone) { this.phone = phone; } @Override public String toString() { return "Student{" + "id=" + id + ", sname='" + sname + '\'' + ", age=" + age + ", phone='" + phone + '\'' + '}'; }}

  3.5 创建StudentServlet

  @WebServlet("/student")public class StudentServlet extends BaseServlet{ private StudentService studentService=new StudentService(); /*POI导入学生信息*/ public void poiImport(HttpServletRequest request, HttpServletResponse response){ System.out.println("POI导入学生信息"); String path="D:\\ssm\\students.xlsx"; try { //创建工作表对象 Workbook workbook=new XSSFWorkbook(path); //获取目标sheet Sheet sheet = workbook.getSheetAt(0); //获取sheet数据总行数 int rows = sheet.getPhysicalNumberOfRows(); //获取sheet中所有数据 for (int i = 1; i < rows; i++) { //获取当前行对象 Row row = sheet.getRow(i); String sname = row.getCell(0).getStringCellValue();//姓名 double value = row.getCell(1).getNumericCellValue();//年龄 Integer age = (int)value; double tel = row.getCell(2).getNumericCellValue();//手机号 BigDecimal bigDecimal=new BigDecimal(tel); String phone = bigDecimal.toString(); //将获取的数据封装到学生对象 Student student=new Student(sname,age,phone); //将数据保存数据库表 studentService.insertStudent(student); } System.out.println("POI导入学生信息完毕!"); response.setContentType("text/html;charset=utf-8"); response.getWriter().write("POI导入学生信息完毕!"); } catch (Exception e) { e.printStackTrace(); } }}

  3.6 创建StudentService

  public class StudentService { private StudentDao studentDao=new StudentDao(); /*增加学生*/ public int insertStudent(Student s){ return studentDao.addStudent(s); }}

  3.7 创建StudentDao

  public class StudentDao extends BaseDao{ /*增加学生*/ public int addStudent(Student s){ String sql="insert into `student` ( `sname`, `age`, `phone`) values (?,?,?)"; return update(sql, s.getSname(), s.getAge(), s.getPhone()); }}

  <%@ page contentType="text/html;charset=UTF-8" language="java" %>

  4.效果图示例

  首页效果如下图:

图片 3

 

  导入成功提示:

图片 4

  导入成功后学生表:

图片 5

  至此,我们就实现了POI导入excel文件的操作,当然还有一些更复杂的操作在这里没有展开,例如导入excel中的部分行、部分列的数据,以及导出数据到excel等操作。

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。

相关推荐

  • springcloud和dubbo的区别是什么? SpringCloud和Dubbo是两个在分布式系统开发中常用的框架,它们有以下几个主要区别:1.生态系统和发展历程:-Dubbo是由阿里巴巴集团开发并开源的,主要在中国的互联网企业中广泛使用,并且有
  • dubbo是什么?有哪些特性?-小王 Dubbo是一个开源的高性能RPC(远程过程调用)框架,由阿里巴巴集团开发并开源。它提供了分布式服务治理的解决方案,旨在简化大规模分布式系统中服务之间的通信和调用。Dubbo的设计目标是提供高性能、透
  • java面试之消息队列mq的实现原理 消息队列(MessageQueue)是一种在应用程序之间传递消息的通信模式。它提供了一种异步的、解耦的方式来实现不同系统、模块或组件之间的通信。消息队列的实现原理可以简要概括如下:1.**消息发布(P
  • java hash 加密字符串,使用 MessageDigest 类 在Java中,可以使用MessageDigest类来进行哈希加密(散列算法)。下面是使用MessageDigest类进行字符串哈希加密的示例:importjava.security.MessageDi
  • java object添加属性怎么实现? 在Java中,一个对象的属性通常是在类的定义中声明的,并通过类的构造函数或方法来进行初始化和设置。但是,如果你想为一个已有的对象动态添加属性,Java并没有直接支持这种操作。然而,你可以使用其他方式来
  • stringbuilder字符串 StringBuilder是一个用于构建和操作字符串的类,通常用于需要频繁拼接和修改字符串的场景,特别是在循环中。在许多编程语言中都有类似于StringBuilder的概念,下面是一个Java语言中使