引入依赖

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

一、导入到excel

1.编写POIUtil类

package com.exp.utils;

import com.exp.model.User;
import org.apache.poi.hssf.usermodel.*;
import org.apache.poi.ss.util.CellRangeAddress; import java.io.FileOutputStream;
import java.io.OutputStream;
import java.util.List; public class POIUtil { public static void export(List<User> userList) throws Exception{
//指定数据存放的位置
OutputStream outputStream = new FileOutputStream("D:\\test.xls");
//1.创建一个工作簿
HSSFWorkbook workbook = new HSSFWorkbook();
//2.创建一个工作表sheet
HSSFSheet sheet = workbook.createSheet("test");
//List<User> userList = userService.selectAll();
//构造参数依次表示起始行,截至行,起始列, 截至列
CellRangeAddress region=new CellRangeAddress(0, 0, 0, 3);
sheet.addMergedRegion(region); HSSFCellStyle style=workbook.createCellStyle();
//水平居中
style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
//垂直居中
style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); HSSFRow row1 = sheet.createRow(0);
HSSFCell cell = row1.createCell(0);
//设置值,这里合并单元格后相当于标题
cell.setCellValue("人员信息表");
//将样式添加生效
cell.setCellStyle(style); for(int i = 0;i<userList.size();i++){
//行
HSSFRow row = sheet.createRow(i+1);
//对列赋值
row.createCell(0).setCellValue(userList.get(i).getId());
row.createCell(1).setCellValue(userList.get(i).getName());
row.createCell(2).setCellValue(userList.get(i).getPassword());
row.createCell(3).setCellValue(userList.get(i).getRemark());
}
workbook.write(outputStream);
outputStream.close();
} }

在TestController中

访问:http://localhost:8080/ssm2/test

在D盘会生成一个test.xls文件打开后如下

二。从excel导出到数据库

1.编写POIUtil工具类

public static List<User> importExcel() throws Exception{
HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(new File("D:\\t1.xls")));
HSSFSheet sheet = null; for(int i = 0;i < workbook.getNumberOfSheets();i++){
//获取每个sheet
sheet = workbook.getSheetAt(i);
List<User> list = new ArrayList<User>();
//getPhysicalNumberOfRows获取有记录的行数
for(int j = 0;j < sheet.getPhysicalNumberOfRows();j++){
Row row = sheet.getRow(j);
if(null!=row){
//getLastCellNum获取最后一列
User user = new User();
for(int k = 0;k < row.getLastCellNum();k++){
if(null!=row.getCell(k)){
if(k==0){
Cell cell = row.getCell(0);
//cell->double
Double d = cell.getNumericCellValue();
//double->int
int id = new Double(d).intValue();
user.setId(id);
}
if(k==1){
Cell cell = row.getCell(1);
//cell->string
user.setName(cell.getStringCellValue().toString());
}
if(k==2){
Cell cell = row.getCell(2);
user.setPassword(cell.getStringCellValue().toString());
}
if(k==3){
Cell cell = row.getCell(3);
user.setRemark(cell.getStringCellValue().toString());
}
} }
list.add(user); } }
System.out.println("读取sheet表:"+ workbook.getSheetName(i) + "完成");
return list;
} return null;
}

在编写工具类的时候遇到的问题总结:

(1)getLastRowNum

如果sheet中一行数据都没有则返回-1,只有第一行有数据则返回0,最后有数据的行是第n行则返回 n-1;

getPhysicalNumberOfRows

获取有记录的行数,即:最后有数据的行是第n行,前面有m行是空行没数据,则返回n-m;

之前写成getLastRowNum()执行到row.getLastCellNum()=-1,获取不到excel中的值

(2)如何在循环里将值赋值到一个对象中,我就写了个if判断

(3)cell->int和string

2.UserMapper.xml

<insert id="insertData" parameterType="list">
insert into user(id,name,password,remark) VALUES
<foreach collection="list" index="index" item="user" separator=",">
(#{user.id},#{user.name},#{user.password},#{user.remark})
</foreach>
</insert>

3.UserMapper和UserService接口一样

int insertData(List<User> users);

4.UserServiceImpl

@Override
public int insertData(List<User> users) {
int num = userMapper.insertData(users);
return num;
}

5.TestController

@RequestMapping("/insertData")
public void insertData() throws Exception{
List<User> users = POIUtil.importExcel();
int num = userService.insertData(users);
if(num > 0){
System.out.println("插入数据成功");
} }

excel数据在D:/t1.xls,数据如下

6.测试

访问:http://localhost:8080/ssm2/insertData

在数据库中查看如下即成功:

<insert id="insertData" parameterType="list">    insert into user(id,name,password,remark) VALUES    <foreach collection="list" index="index" item="user" separator=",">      (#{user.id},#{user.name},#{user.password},#{user.remark})    </foreach>  </insert>

POI实现excel的导入导出的更多相关文章

  1. poi实现excel的导入导出功能

    Java使用poi实现excel的导入导出功能: 工具类ExcelUtil,用于解析和初始化excel的数据:代码如下 package com.raycloud.kmmp.item.service.u ...

  2. SSM中使用POI实现excel的导入导出

    环境:导入POI对应的包 环境: Spring+SpringMVC+Mybatis POI对应的包 <dependency> <groupId>org.apache.poi&l ...

  3. java实现excel的导入导出(poi详解)[转]

    java实现excel的导入导出(poi详解) 博客分类: java技术 excel导出poijava  经过两天的研究,现在对excel导出有点心得了.我们使用的excel导出的jar包是poi这个 ...

  4. java 中Excel的导入导出

    部分转发原作者https://www.cnblogs.com/qdhxhz/p/8137282.html雨点的名字  的内容 java代码中的导入导出 首先在d盘创建一个xlsx文件,然后再进行一系列 ...

  5. JAVA对Excel的导入导出

    今天需要对比2个excel表的内容找出相同:由于要学的还很多上手很慢所以在这做个分享希望对初学的有帮助: 先是pom的配置: <dependency> <groupId>org ...

  6. Excel导入导出工具(简单、好用且轻量级的海量Excel文件导入导出解决方案.)

    Excel导入导出工具(简单.好用且轻量级的海量Excel文件导入导出解决方案.) 置顶 2019-09-07 16:47:10 $9420 阅读数 261更多 分类专栏: java   版权声明:本 ...

  7. excel的导入导出的实现

    1.创建Book类,并编写set方法和get方法 package com.bean; public class Book { private int id; private String name; ...

  8. c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出

    c# .Net :Excel NPOI导入导出操作教程之读取Excel文件信息及输出 using NPOI.HSSF.UserModel;using NPOI.SS.UserModel;using S ...

  9. OpenXml Excel数据导入导出(含图片的导入导出)

    声明:里面的很多东西是基于前人的基础上实现的,具体是哪些人 俺忘了,我做了一些整合和加工 这个项目居于openxml做Excel的导入导出,可以用OpenXml读取Excel中的图片 和OpenXml ...

随机推荐

  1. WIN10 网卡驱动异常代码56的问题及解决方法

    故障描述: 原来使用正常的一个微机室,突然一天控制端主机网络连接异常,平时的网络控制软件无法使用.检查网络配置正常,网络诊断.修复.将网卡禁用也没有效果:后来删除网卡想重装,则恶运开始,无法安装驱动: ...

  2. 数据库里的回车字符导致取过来的json字符串不规范的问题

    转发:https://bbs.csdn.net/topics/380192638 你可以报保存数据库之前,进行 替换 str = str.Replace("\r\n"," ...

  3. Python爬虫下载酷狗音乐

    目录 1.Python下载酷狗音乐 1.1.前期准备 1.2.分析 1.2.1.第一步 1.2.2.第二步 1.2.3.第三步 1.2.4.第四步 1.3.代码实现 1.4.运行结果 1.Python ...

  4. LeetCode通关:听说链表是门槛,这就抬脚跨门而入

    分门别类刷算法,坚持,进步! 刷题路线参考:https://github.com/youngyangyang04/leetcode-master       https://github.com/ch ...

  5. 微信小程序云开发-列表数据分页加载显示

    一.准备工作 1.创建数据库nums,向数据库中导入108条数据 2.修改数据库表nums的权限 二.新建页面ListPaginated 1.wxml文件 <!-- 显示列表数据 --> ...

  6. Spring 学习笔记(2) Spring Bean

    一.IoC 容器 IoC 容器是 Spring 的核心,Spring 通过 IoC 容器来管理对象的实例化和初始化(这些对象就是 Spring Bean),以及对象从创建到销毁的整个生命周期.也就是管 ...

  7. nmcli命令行修改网络连接名称

    目前在网上能找到的文章中,使用nmcli命令修改Linux系统中网卡连接的名称都是先创建新的连接,然后删除旧的连接的方式 此种方式其实完全不恰当,简直就是在浪费时间,nmcli命令本身就提供了直接修改 ...

  8. Spring Boot的MyBatis注解:@MapperScan和@Mapper(十七)

    1.Spring Boot与MyBatis融合的矛盾问题: Spring家族的使命就是为了简化而生,但是随着Spring的发展壮大,有点事与愿违了.为了坚持初心,Spring家族祭出了一大杀器---S ...

  9. 轮播图 -- view, swiper

    效果图 制作步骤: 一.创建一个page 二.编写demo.wxml写界面元素 <!--miniprogram/pages/demo/demo.wxml--> <view class ...

  10. 两年Android开发三面上岸腾讯,这些核心知识点建议收藏

    概述 感觉毕业后时间过得真快啊,从 19 年 7 月本科毕业入职后,到现在快两年了,前段时间金三银四期间想着找一个新的工作,前前后后花了一个多月的时间复习以及面试,面试好几家大厂,最后选择了腾讯.也祝 ...