IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 基于Hutool,Excel文件导出工具,支持表头合并,CSV文件大量导出 -> 正文阅读

[JavaScript知识库]基于Hutool,Excel文件导出工具,支持表头合并,CSV文件大量导出

前言:对excel文件操作的封装有 easyPoi, Hutool等已经很完善了。但还是有些不尽人意,本工具就是基于 Hutool的进一步封装。想让文件导出更加方便

注意:该工具使用新注解@Header表示表头,和原Hutool中的@Alias,@PropIgnore两个注解会有冲突,避免同时使用,否则会导致导出异常

  • 普通文件导出

效果:

?????????

代码:

@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class Simple {

    @Header("ID")
    private int id;

    @Header("名称")
    private String name;

    @Header("布尔")
    private boolean flag;

    @Header("数量")
    private double count;

}
    /**
     * 测试导出简单数据
     */
    @Test
    public void testSimple() {
        File file = new File("./file/simple.xlsx");
        ExcelWriter excelWriter = ExcelUtil.getWriter(file);

        List<Simple> simpleList = new ArrayList<>();
        for (int i = 0; i < 3; i++) {
            simpleList.add(new Simple(i, "test" + i, true, i * 10));
        }

        DataKit.exportXlsx(excelWriter, simpleList, null);
        excelWriter.close();
    }
  • 合并表头文件导出

?效果:?

代码:

@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class Merge {

    @Header("ID")
    private int id;

    @Header("名称")
    private String name;

    @Header("布尔")
    private boolean flag;

    @Header({"统计", "数量1"})
    private double cnt1;

    @Header({"统计", "数量2"})
    private double cnt2;

    @Header({"统计", "数量3"})
    private double cnt3;

    @Header({"测试1", "测试"})
    private String test1;

    @Header({"测试2", "测试"})
    private String test2;

    @Header({"合并", "数量"})
    private double val1;

    @Header({"合并", "数量"})
    private double val2;
}
    /**
     * 测试导出合并头部数据
     */
    @Test
    public void testMerge() {
        File file = new File("./file/merge.xlsx");
        ExcelWriter excelWriter = ExcelUtil.getWriter(file);

        List<Merge> mergeList = new ArrayList<>();
        for (int i = 0; i < 3; i++) {
            mergeList.add(new Merge(i, "test" + i, true, i * 10, i / 10d, i * 8, "demo" + i, "abc" + i, i / 8d, i * 5.5));
        }

        DataKit.exportXlsx(excelWriter, mergeList, null);
        excelWriter.close();
    }

?解析:表头值是数组,每一个下标对应一行,在同行和同列的名称如果相同将进行合并。如果有多行是,而某列数组只有一个值则向对应列合并。具体可以观察案例了解

  • 携带图片文件导出

?效果:

??????????

代码:

    /**
     * 测试导出简单数据携带图片
     */
    @Test
    public void testSimpleWithImg() {
        File file = new File("./file/simple-img.xlsx");
        ExcelWriter excelWriter = ExcelUtil.getWriter(file);

        List<Simple> simpleList = new ArrayList<>();
        for (int i = 0; i < 3; i++) {
            simpleList.add(new Simple(i, "test" + i, true, i * 10));
        }

        // 加上图片路径回调,可以更加 数据内容来动态对于图片路径
        DataKit.exportXlsx(excelWriter, simpleList, (simple)-> "https://www.baidu.com/img/flexible/logo/pc/result.png");
        excelWriter.close();
    }
  • 自定义排序文件导出

?效果:

??????????

代码:

@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class Order {

    @Header(value = "ID", order = 3)
    private int id;

    @Header(value = "名称", order = 0)
    private String name;

    @Header(value = "布尔", order = 2)
    private boolean flag;

    @Header(value = "数量", order = 1)
    private double count;

}
    /**
     * 测试导出简单带排序数据
     */
    @Test
    public void testOrder() {
        File file = new File("./file/order.xlsx");
        ExcelWriter excelWriter = ExcelUtil.getWriter(file);

        List<Order> orderList = new ArrayList<>();
        for (int i = 0; i < 3; i++) {
            orderList.add(new Order(i, "test" + i, true, i * 10));
        }

        DataKit.exportXlsx(excelWriter, orderList, null);
        excelWriter.close();
    }
  • 大数据分段导出

?效果:

??????????

代码:

    /**
     * 测试使用csv文件方式,导出大量数据
     */
    @Test
    public void testExportBigdataToCsvByRange() {
        File file = new File("./file/bigdata.csv");

        // 定义开始页,
        int page = 1;
        // 定义每页查询的数量
        int limit = 1000;

        // 分段加载数据写入文件
        DataKit.exportCsvByRange(file, page, limit, (p, l) -> {
            if (p == 5) {
                return null;
            }

            // 模拟数据获取,真实环境这里去查询数据库
            List<Simple> simpleList = new ArrayList<>();
            for (int i = 0; i < 10; i++) {
                simpleList.add(new Simple((p - 1) * 10 + i, "test" + i, true, i * 10));
            }
            return simpleList;
        });
    }

?源码:https://gitee.com/wsitm/java_test.git

  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-05-05 11:09:15  更:2022-05-05 11:14:12 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/11 6:24:26-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码