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

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

代码:

java 复制代码
 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.遍历每一列即可

相关推荐
Lionel_SSL3 分钟前
《深入理解Java虚拟机》第三章读书笔记:垃圾回收机制与内存管理
java·开发语言·jvm
记得开心一点嘛5 分钟前
手搓Springboot
java·spring boot·spring
老华带你飞33 分钟前
租房平台|租房管理平台小程序系统|基于java的租房系统 设计与实现(源码+数据库+文档)
java·数据库·小程序·vue·论文·毕设·租房系统管理平台
独行soc34 分钟前
2025年渗透测试面试题总结-66(题目+回答)
java·网络·python·安全·web安全·adb·渗透测试
脑子慢且灵1 小时前
[JavaWeb]模拟一个简易的Tomcat服务(Servlet注解)
java·后端·servlet·tomcat·intellij-idea·web
华仔啊2 小时前
SpringBoot 中 6 种数据脱敏方案,第 5 种太强了,支持深度递归!
java·后端
异常驯兽师3 小时前
Spring 中处理 HTTP 请求参数注解全解析
java·spring·http
连合机器人3 小时前
晨曦中的守望者:当科技为景区赋予温度
java·前端·科技
AD钙奶-lalala4 小时前
idea新建的项目new 没有java class选项
java·ide·intellij-idea
sheji34164 小时前
【开题答辩全过程】以 12306候补购票服务系统为例,包含答辩的问题和答案
java·eclipse