基于反射解析Excel生成集合对象

本文介绍了如何通过反射机制将Excel文件内容解析成Java集合对象。主要涉及装载Excel流、组装单个对象以及针对字符串和数字类型的值进行处理。目前只支持这两种类型,但可以扩展以处理更多类型的值。
摘要由CSDN通过智能技术生成

装载流

public static List<Map<String, Object>> importExcel(MultipartFile file, Object obj) throws Exception {

        //装载流
        XSSFWorkbook hw = new XSSFWorkbook(file.getInputStream());

        //获取第一个sheet页
        XSSFSheet sheet = hw.getSheetAt(0);

        //容器
        List<Map<String, Object>> ret = new ArrayList<Map<String, Object>>();

        //遍历行 从下标第一行开始(去除标题)
        for (int i = 2; i <= sheet.getLastRowNum(); i++) {
            XSSFRow row = sheet.getRow(i);
            if (row != null) {
                //装载obj
                ret.add(dataObj(obj, row));
            }
        }
        return ret;
    }

拼装单个obj

private static Map<String, Object> dataObj(Object obj, XSSFRow row) throws Exception {
        Class<?> rowClazz = obj.getClass();
        Field[] fields = FieldUtils.getAllF
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值