Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Java工具集-Excel行转换为对象工具类

Java工具集-Excel行转换为对象工具类

作者头像
cwl_java
发布于 2020-06-10 07:48:57
发布于 2020-06-10 07:48:57
1K00
代码可运行
举报
文章被收录于专栏:cwl_Javacwl_Java
运行总次数:0
代码可运行
代码示例
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.simple.util.poi;

import com.simple.util.time.DateUtil;
import org.apache.commons.collections.CollectionUtils;
import org.apache.commons.lang3.StringUtils;

import java.io.Serializable;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

/**
 * @program: simple_tools
 * @description: Excel行转换为对象工具类
 * @author: Mr.chen
 * @create: 2020-06-09 09:50
 **/
public class ExcelRowConvert2ObjectUtil {
    /**
     * 检查表头
     *
     * @param headRow
     */
    private Map<String, Integer> checkTableHead(Map<String, String> headMap, List<String> headRow) {
        if (CollectionUtils.isEmpty(headRow)) {
            throw new RuntimeException("import data is empty");
        }
        Map<String, Integer> indexMap = new HashMap<String, Integer>();
        int repeat = 0;
        int index = 0;
        boolean flag = false;
        for (String columnName : headRow) {
            repeat = 0;
            for (Map.Entry<String, String> mp : headMap.entrySet()) {
                if (mp.getKey().equals(StringUtils.trim(columnName))) {
                    ++repeat;
                    flag = true;
                }
            }
            if (repeat > 1) {
                throw new RuntimeException("import data is empty");
            }
            if (!flag) {
                throw new RuntimeException("import data is empty");
            }
            indexMap.put(columnName, index);
            ++index;
        }
        return indexMap;
    }

    /**
     * 处理数据
     * @param cls
     * @param headMap
     * @param sheets
     * @param <T>
     * @return
     */
    @SuppressWarnings("unchecked")
    public <T> List<T> toList(Class<?> cls, Map<String, String> headMap, List<DataGird> sheets) {
        if (cls == null) {
            throw new RuntimeException("object is not exsit");
        }
        if (headMap == null || headMap.size() <= 0) {
            throw new RuntimeException("import data is empty");
        }
        // 第一个样单
        DataGird excel = sheets.get(0);
        List<List<String>> rows = excel.getData();
        if (CollectionUtils.isEmpty(rows) && rows.size() <= 1) {
            throw new RuntimeException("操作失败 导入数据为空");
        }
        // 标题行
        List<String> headRow = rows.get(0);
        Map<String, Integer> map = this.checkTableHead(headMap, headRow);
        List<T> objs = new ArrayList<T>();
        T instance = null;
        try {
            Field[] fields = cls.getDeclaredFields();
            List<String> datas = null;
            for (int i = 1, length = rows.size(); i < length; i++) {
                datas = rows.get(i);
                instance = (T) cls.newInstance();
                for (String headName : headRow) {
                    for (Map.Entry<String, Integer> mp : map.entrySet()) {
                        if (mp.getKey().equals(headName)) {
                            String column = headMap.get(headName);
                            int index = mp.getValue().intValue();
                            if (datas.size() > index) {
                                String value = datas.get(index);
                                for (Field field : fields) {
                                    if (field.getName().equals(column)) {
                                        field.setAccessible(true);
                                        String fldtype = field.getType().getSimpleName();
                                        if ("String".equals(fldtype)) {
                                            field.set(instance, value);
                                        } else if ("Double".equals(fldtype)) {
                                            double val = Double.valueOf(StringUtils.isNotBlank(value) ? Double.parseDouble(value) : 0);
                                            field.set(instance, val);
                                        } else if ("Float".equals(fldtype)) {
                                            float val = Float.valueOf(StringUtils.isNotBlank(value) ? Float.parseFloat(value) : 0);
                                            field.set(instance, val);
                                        } else if ("Integer".equals(fldtype)) {
                                            int val = Integer.valueOf(StringUtils.isNotBlank(value) ? Integer.parseInt(value) : 0);
                                            field.set(instance, val);
                                        } else if ("Date".equals(fldtype)) {
                                            Date val = DateUtil.parseDate(value, new String[]{"yyyy-MM-dd"});
                                            field.set(instance, val);
                                        } else if ("Long".equals(fldtype)) {
                                            long val = Long.valueOf(StringUtils.isNotBlank(value) ? Long.parseLong(value) : 0);
                                            field.set(instance, val);
                                        }

                                    }
                                }
                            }
                        }
                    }
                }
                objs.add(instance);
            }
        } catch (Exception e) {
            throw new RuntimeException("操作失败");
        }

        return objs;
    }
}

class DataGird implements Serializable {
    /**
     *
     */
    private static final long serialVersionUID = 1L;
    private String title; // 标题
    private List<List<String>> data; // 数据
    private int columns; // 列数

    public String getTitle() {
        return title;
    }

    public void setTitle(String title) {
        this.title = title;
    }

    public List<List<String>> getData() {
        return data;
    }

    public void setData(List<List<String>> data) {
        this.data = data;
    }

    public int getColumns() {
        return columns;
    }

    public void setColumns(int columns) {
        this.columns = columns;
    }

}
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020/06/09 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Java工具集-类(ClassUtils)
简单工具类 写作初衷:由于日常开发经常需要用到很多工具类,经常根据需求自己写也比较麻烦 网上好了一些工具类例如commom.lang3或者hutool或者Jodd这样的开源工具,但是 发现他们之中虽然设计不错,但是如果我想要使用,就必须要引入依赖并且去维护依赖,有些 甚至会有存在版本编译不通过问题,故此想要写作一个每个类都可以作为独立工具类使用 每个使用者只需要复制该类,到任何项目当中都可以使用,所以需要尊从以下两个原则才能 做到.在此诚邀各位大佬参与.可以把各自用过的工具,整合成只依赖JDK
cwl_java
2019/10/26
8830
Java拖拽排序工具类「建议收藏」
发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/147752.html原文链接:https://javaforall.cn
全栈程序员站长
2022/09/07
1K0
excel转sql小工具
程序猿川子
2024/10/30
1510
excel转sql小工具
Java工具集-AES加密工具类
代码示例 package com.simple.util.security; /** * @program: simple_tools * @description: AES加密 * @author: Mr.chen * @create: 2020-03-08 22:00 **/ import com.simple.util.base.StringUtils; import sun.misc.BASE64Decoder; import sun.misc.BASE64Encoder; impo
cwl_java
2020/03/11
8.4K1
记一次悲惨的 Excel 导出事件
话说这个背景挺惨的,某系统使用了poi-ooxml-3.5-final做excel导出功能。起初使用该版本的poi的HSSF配合多线程生成excel,没有任何问题,后来改成了XSSF生成后上线,导出3w条数据时,cpu使用率达到了100%,内存达到了100%,打死了整个服务器!
芋道源码
2019/10/29
1.3K0
Java工具集-复杂更新逻辑工具
简单工具类 写作初衷:由于日常开发经常需要用到很多工具类,经常根据需求自己写也比较麻烦 网上好了一些工具类例如commom.lang3或者hutool或者Jodd这样的开源工具,但是 发现他们之中虽然设计不错,但是如果我想要使用,就必须要引入依赖并且去维护依赖,有些 甚至会有存在版本编译不通过问题,故此想要写作一个每个类都可以作为独立工具类使用 每个使用者只需要复制该类,到任何项目当中都可以使用,所以需要尊从以下两个原则才能 做到.在此诚邀各位大佬参与.可以把各自用过的工具,整合成只依赖JDK
cwl_java
2019/10/26
5510
Quartz2.x动态Job工具类 原
有些需求,需要动态启动一个定时器,然后在一定条件下再停止。比如通过rest控制jenkins做发布,当发起一个构建后,就需要定时去查询构建状态,在构建完成后再停止定时器,下面是一个通用的定时器工具类。
尚浩宇
2018/10/10
6480
JAVA实现DAO基本层CRUD操作
随着shh2各种操作方便框架。越来越多JAVA WEB效率,可是,假设在不了解这些框架使用的场合的情况下,一拿到项目就盲目地选择这些框架进行系统架构的搭建,就有可能造成非常多不是必需的资源浪费。
全栈程序员站长
2022/07/05
1.1K0
mybatis-plus随机查询工具类
这里的USER_MAPPER我们可以使用任意一个mapper,我这里使用的是静态注入的方式
阿超
2022/08/16
1.5K0
mybatis-plus随机查询工具类
Java工具集-统计学工具类
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
cwl_java
2019/11/07
9400
Java工具集-日期转换工具类
代码示例 import org.apache.commons.collections.CollectionUtils; import org.apache.commons.lang3.StringUtils; import java.util.ArrayList; import java.util.Collections; import java.util.List; /** * @program: simple_tools * @description: 日期转换工具类 * @author: M
cwl_java
2020/06/10
5680
简单java代码生成器的开发教程(一),根据数据库表逆向工程生成实体类(附源码)
以前开发过完整的快速开发平台,想分享里面的基本代码生成的开发流程,大概就两个重点,一代码生成引擎,二是编写模版
全栈程序员站长
2022/08/30
1.6K0
简单java代码生成器的开发教程(一),根据数据库表逆向工程生成实体类(附源码)
Java工具集-判断(AssertUtil)
简单工具类 写作初衷:由于日常开发经常需要用到很多工具类,经常根据需求自己写也比较麻烦 网上好了一些工具类例如commom.lang3或者hutool或者Jodd这样的开源工具,但是 发现他们之中虽然设计不错,但是如果我想要使用,就必须要引入依赖并且去维护依赖,有些 甚至会有存在版本编译不通过问题,故此想要写作一个每个类都可以作为独立工具类使用 每个使用者只需要复制该类,到任何项目当中都可以使用,所以需要尊从以下两个原则才能 做到.在此诚邀各位大佬参与.可以把各自用过的工具,整合成只依赖JDK
cwl_java
2019/10/26
1.7K0
Java导入导出Excel工具类ExcelUtil
前段时间做的分布式集成平台项目中,许多模块都用到了导入导出Excel的功能,于是决定封装一个ExcelUtil类,专门用来处理Excel的导入和导出
用户7705674
2021/09/23
3.4K0
JAVA8实战 - Optional工具类
没错,这又是一个新的专栏,JAVA8可以说是JAVA划时代的一个版本,几乎是让JAVA焕发了第三春(第二春在JDK5),当然里面的新特性也是十分重要的,虽然Java现在都已经到了10几的版本,但是国内多数使用的版本还是JAVA8,所以这个系列将会围绕Java8的新特性和相关工具做一些总结。希望对大家日常学习和工作中有所帮助。
阿东
2021/08/16
1.8K0
【Java框架型项目从入门到装逼】第十节 simple-jdbc源码
这一节就简单贴一下simple-jdbc框架的源码,其实也没多少东西,都很简单的啦。这个小框架就是对之前 文章发布系统博客 中封装的jdbc工具类,进行的一个强化。 目录结构: 1、DBCP_sour
剽悍一小兔
2018/05/17
7440
Java DO到DTO转换工具类和BeanUtils.copyProperties()
项目中需要使用对象(DO)属性赋值给包含其属性子集的对象(DTO)或者显示层对象(VO)。
明明如月学长
2021/08/27
1.4K0
30个类手写Spring核心原理之自定义ORM(下)(7)
EntityOperation主要实现数据库表结构和对象类结构的映射关系,代码如下:
Tom弹架构
2021/12/17
5540
Java 基于反射的通用树形结构工具类
在日常的开发中, 经常会遇到许多树形结构的场景, 如菜单树, 部门树, 目录树等. 而这些一般都会涉及到要将数据库查询出来的集合转化为树形结构的功能. 由于 list -> tree 是一个比较通用的功能, 无非就是根据 id, pid, children 这三个字段进行转换. 但由于字段名可能不一致, 如菜单里可能叫 menuId, 而部门里叫 deptId,所以我用反射来实现了一个通用的工具类, 来进行转换.
一份执着✘
2019/12/30
2.3K0
ElasticSearch 工具类封装(基于ElasticsearchTemplate)
1.抽象接口定义 1 public abstract class SearchQueryEngine<T> { 2 3 @Autowired 4 protected ElasticsearchTemplate elasticsearchTemplate; 5 6 public abstract int saveOrUpdate(List<T> list); 7 8 public abstract <R> List<R> aggregati
肖哥哥
2019/01/28
6.7K0
相关推荐
Java工具集-类(ClassUtils)
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验