博客
关于我
Java导入Excel工具类使用教程
阅读量:671 次
发布时间:2019-03-15

本文共 2530 字,大约阅读时间需要 8 分钟。

前言

本工具类提供了Excel导入功能,通过反射机制将Excel中数据映射到实体类中,从而获取Excel数据。工具类依赖org.apache.poi包,支持RESTful API,适用于Spring MVC环境。

一.本工具类支持功能

  • 支持File类型和MultipartFile类型导入
  • 支持Excel2003及以上版本
  • 支持批量导入和单文件导入

二.工具类依赖

工具类依赖以下JAR包:

org.apache.poi
poi
4.1.0

三.工具类使用方法

1. 导入MultipartFile类型(推荐)

适用于Web页面中通过MultipartFile上传文件场景,可直接转换为List<List<Object>>

@PostMapping(value = "/project/import")public ResultObject importAlarmEvents(@RequestParam MultipartFile file) {    ResultObject result = new ResultObject();    try {        List
> excelData = ImportExcelUtil.importExcelMultipartFile(file, 1, 0, EventDTO.class); if (excelData == null || excelData.isEmpty()) { result.setMessage("导入失败,Excel内容为空"); return result; } List
alarmList = new ArrayList<>(); for (List
list : excelData) { alarmList.add((EventDTO) list); } Map
res = eventService.importEvent(alarmList); } catch (Exception e) { result.setMessage(e.getMessage()); } return result;}

2. 导入文件格式为File

适用于Web页面中通过File上传文件场景,可直接转换为List<List<Object>>

@PostMapping(value = "/project/import")public ResultObject importAlarmEvents(@RequestParam File file) {    ResultObject result = new ResultObject();    try {        List
> excelData = ImportExcelUtil.importExcelFile(file, 1, 0, EventDTO.class); if (excelData == null || excelData.isEmpty()) { result.setMessage("导入失败,Excel内容为空"); return result; } List
alarmList = new ArrayList<>(); for (List
list : excelData) { alarmList.add((EventDTO) list); } Map
res = eventService.importEvent(alarmList); } catch (Exception e) { result.setMessage(e.getMessage()); } return result;}

实体类示例

注意:实体类的属性声明顺序必须与Excel列头顺序一致,否则会导致数据对应错误。以下是一个示例:

package com.entity.dto;import java.io.Serializable;@SuppressWarnings("serial")public class EventDTO implements Serializable {    // 列字段1    private String name;    // 列字段2    private String code;    public String getName() {        return name;    }    public void setName(String name) {        this.name = name;    }    public String getCode() {        return code;    }    public void setCode(String code) {        this.code = code;    }}

Excel实用教程集锦

  • 简单Excel导出推荐使用工具类方式,配置最简单
  • 对导出样式要求极高的还原度推荐使用FreeMarker模板引擎
  • Freemarker导出的Excel为xml格式,可通过重命名为xls解决格式问题
  • Freemarker无法导出带有图片的Excel,本教程提供解决方案
  • 转载地址:http://zqfqz.baihongyu.com/

    你可能感兴趣的文章
    netty底层源码探究:启动流程;EventLoop中的selector、线程、任务队列;监听处理accept、read事件流程;
    查看>>
    Netty核心模块组件
    查看>>
    Netty框架的服务端开发中创建EventLoopGroup对象时线程数量源码解析
    查看>>
    Netty源码—2.Reactor线程模型一
    查看>>
    Netty源码—4.客户端接入流程一
    查看>>
    Netty源码—4.客户端接入流程二
    查看>>
    Netty源码—5.Pipeline和Handler一
    查看>>
    Netty源码—6.ByteBuf原理二
    查看>>
    Netty源码—7.ByteBuf原理三
    查看>>
    Netty源码—7.ByteBuf原理四
    查看>>
    Netty源码—8.编解码原理二
    查看>>
    Netty源码解读
    查看>>
    Netty的Socket编程详解-搭建服务端与客户端并进行数据传输
    查看>>
    Netty相关
    查看>>
    Network Dissection:Quantifying Interpretability of Deep Visual Representations(深层视觉表征的量化解释)
    查看>>
    Network Sniffer and Connection Analyzer
    查看>>
    NFS共享文件系统搭建
    查看>>
    ng 指令的自定义、使用
    查看>>
    nginx + etcd 动态负载均衡实践(二)—— 组件安装
    查看>>
    Nginx + uWSGI + Flask + Vhost
    查看>>