分享一个java中读取excel的方法

一、前端传递后端一个excel文件

代码:

 String file = param.get("file").split(",")[1];
        byte[] content = Base64.decodeBase64(file);
        InputStream inputStream = new ByteArrayInputStream(content);
        Map<String, List<Map<String, String>>> result = XSSFUtil.read(inputStream);
  for (Map.Entry<String, List<Map<String, String>>> entry : result.entrySet()) {
            List<Map<String, String>> val = entry.getValue();
            for (int i = 0; i < val.size(); i++) {
                Map<String, String> temp = val.get(i);
                AdditionalRecordInfo additionalRecordInfo = new AdditionalRecordInfo();
                for (Map.Entry<String, String> tempEntry : temp.entrySet()) {
                    String k = tempEntry.getKey();
                    String v = tempEntry.getValue();
    }
  }
}

1.String file = param.get("file").split(",")[1];:从param中获取名为"file"的参数值,假定这个值是一个包含Base64编码的字符串。通过split(",")方法将字符串按逗号分割,然后取第二部分(索引为1的部分),这是因为Base64编码的字符串通常以"data:image/xxx;base64,"开头,实际数据在逗号之后。

2.byte[] content = Base64.decodeBase64(file);:使用Apache Commons Codec库中的Base64类的decodeBase64方法将Base64编码的字符串解码为字节数组。这样就得到了原始的文件内容。

3.InputStream inputStream = new ByteArrayInputStream(content);:将字节数组包装成ByteArrayInputStream,以便后续处理。ByteArrayInputStream是一个InputStream的实现类,可以用于从字节数组中读取数据。

4.Map<String, List<Map<String, String>>> result = XSSFUtil.read(inputStream);:使用XSSFUtil工具类的read方法读取Excel文件的内容。result是一个Map,其中键是Excel的工作表名称,值是该工作表中的数据,数据是以List包装的Map

5.遍历每一列即可

  • 6
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

山川志~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值