SpringBoot 我随手封装了一个万能的导出excel工具,传什么都能导出 您所在的位置:网站首页 封装工具是什么 SpringBoot 我随手封装了一个万能的导出excel工具,传什么都能导出

SpringBoot 我随手封装了一个万能的导出excel工具,传什么都能导出

#SpringBoot 我随手封装了一个万能的导出excel工具,传什么都能导出| 来源: 网络整理| 查看: 265

点击关注公众号:互联网架构师,后台回复 2T获取2TB学习资源!

上一篇:Alibaba开源内网高并发编程手册.pdf

前言

如题,这个小玩意,就是不限制你查的是哪张表,用的是什么类。

我直接一把梭,嘎嘎给你一顿导出。

833d2833d3620f289bc73a5f147751f3.png

我知道,这是很多人都想过的, 至少我就收到很多人问过我这个类似的问题。

我也跟他们说了,但是他们就是不动手,其实真的很简单。

不动手怎么办? 我出手呗。

不多说开搞 。

正文

玩法很简单,我之前有写过一篇利用csv文件内容格式做excel文件导出的。

如果没有看过的,还等什么,现在就去看看:

要实现的效果 :

类是不确定的 ,User ?Student ?  District ?   不确定。

但是呢我们封装出来的函数,要足够支撑不同的类,我们自动去读取遍历list ,然后导出生成文件。

核心的思路是什么 ?

其实就还是利用csv文件的内容格式本质 ,看这两幅图 :

6ad100197f20e43fe228c8112552a8ad.jpeg 5160f53b5a59dce61968cb4bfaeceff9.jpeg 我们要实现万能的类导出excel !!!

思路是什么 :

① 我们从不确定的类 的集合list 中,取出 里面的类。

反射一手,拿出里面的属性名, 做第一行表格行标题名称拼接。

②拼接内容

因为类不确定,那么我们就采取反射把类全部字段属性作为key丢到map里面,同时把值丢到value里面。

这样我们拼接内容的时候只需要根据map 嘎嘎一顿遍历 拼接即可。

1.依赖

    org.apache.poi     poi-ooxml     3.15     org.apache.poi     poi-scratchpad     3.15     com.alibaba     fastjson     1.2.69     commons-io     commons-io     2.5

2. 核心的工具类,函数我都封装好了

MyCsvFileUtil.java

import lombok.extern.slf4j.Slf4j; import org.apache.commons.io.IOUtils;   import java.io.File; import java.io.FileOutputStream; import java.io.IOException; import java.io.OutputStreamWriter; import java.lang.reflect.Field; import java.lang.reflect.Method; import java.text.SimpleDateFormat; import java.util.*;   /**  * @author JCccc  * @Remark 是我  */ @Slf4j public class MyCsvFileUtil {     public static final String FILE_SUFFIX = ".csv";     public static final String CSV_DELIMITER = ",";     public static final String CSV_TAIL = "\r\n";     protected static final String DATE_STR_FILE_NAME = "yyyyMMddHHmmssSSS";       /**      * 将字符串转成csv文件      */     public static void createCsvFile(String savePath, String contextStr) throws IOException {           File file = new File(savePath);         //创建文件         file.createNewFile();         //创建文件输出流         FileOutputStream fileOutputStream = new FileOutputStream(file);         //将指定字节写入此文件输出流         fileOutputStream.write(contextStr.getBytes("gbk"));         fileOutputStream.flush();         fileOutputStream.close();     }       /**      * 写文件      *      * @param fileName      * @param content      */     public static void writeFile(String fileName, String content) {         FileOutputStream fos = null;         OutputStreamWriter writer = null;         try {             fos = new FileOutputStream(fileName, true);             writer = new OutputStreamWriter(fos, "GBK");             writer.write(content);             writer.flush();         } catch (Exception e) {             log.error("写文件异常|{}", e);         } finally {             if (fos != null) {                 IOUtils.closeQuietly(fos);             }             if (writer != null) {                 IOUtils.closeQuietly(writer);             }         }     }       /**      * 构建文件名称      * @param dataList      * @return      */     public static String buildCsvFileFileName(List dataList) {         return dataList.get(0).getClass().getSimpleName() + new SimpleDateFormat(DATE_STR_FILE_NAME).format(new Date()) + FILE_SUFFIX;     }       /**      * 构建excel 标题行名      * @param dataList      * @return      */     public static String buildCsvFileTableNames(List dataList) {         Map map = toMap(dataList.get(0));         StringBuilder tableNames = new StringBuilder();         for (String key : map.keySet()) {             tableNames.append(key).append(MyCsvFileUtil.CSV_DELIMITER);         }         return tableNames.append(MyCsvFileUtil.CSV_TAIL).toString();     }       /**      * 构建excel内容      * @param dataLists      * @return      */     public static String buildCsvFileBodyMap(List dataLists) {         //不管你传什么玩意,我都给你反射一手,搞成Map         List mapList = new ArrayList();         for (Object o : dataLists) {             mapList.add(toMap(o));         }         //然后利用csv格式,对着map嘎嘎一顿拼接数据         StringBuilder lineBuilder = new StringBuilder();         for (Map rowData : mapList) {             for (String key : rowData.keySet()) {                 Object value = rowData.get(key);                 if (Objects.nonNull(value)) {                     lineBuilder.append(value).append(MyCsvFileUtil.CSV_DELIMITER);                 } else {                     lineBuilder.append("--").append(MyCsvFileUtil.CSV_DELIMITER);                 }             }             lineBuilder.append(MyCsvFileUtil.CSV_TAIL);         }         return lineBuilder.toString();     }       /**      * 类转map      * @param entity      * @param       * @return      */     public static Map toMap(T entity){         Class


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有