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

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

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

装载流

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.getAllFields(rowClazz);
        if (fields == null || fields.length < 1) {
            return null;
        }

        //容器
        Map<String, Object> map = new HashMap<String, Object>();

        //注意excel表格字段顺序要和obj字段顺序对齐 (如果有多余字段请另作特殊下标对应处理)
        for (int j = 0; j < fields.length; j++) {
            map.put(fields[j].getName(), getVal(row.getCell(j)));
        }
        return map;
    }

处理val(暂时只处理string和number,可以自己添加自己需要的val类型)

public static String getVal(XSSFCell hssfCell) {
        if (hssfCell != null ){
            if ( hssfCell.getCellType() == HSSFCell.CELL_TYPE_STRING) {
                return hssfCell.getStringCellValue().replaceAll("\\s*", "");
            }
            if ( hssfCell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC) {
                return String.valueOf(hssfCell.getNumericCellValue());
            }
            return hssfCell.getStringCellValue();
        }else {
         return "";
        }
    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值