热门标签 | HotTags
当前位置:  开发笔记 > 运维 > 正文

java读取简单excel通用工具类

这篇文章主要为大家详细介绍了java读取简单excel通用工具类,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了java读取简单excel通用工具类的具体代码,供大家参考,具体内容如下

读取excel通用工具类

import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.CellType;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;


/**
 * 读取Excel通用工具类
 * @author zql
 */
public class ReadExcel {

 /**
 * 读取Excel
 * 
 * @param filepath 文件路径
 * @param filename 文件名,包括扩展名
 * @param startrow 开始行号,索引从0开始
 * @param startcol 开始列号,索引从0开始
 * @param sheetnum 工作簿,索引从0开始
 * @return
 */
 public List> readExcel(String filepath, String filename, int startrow, int startcol, int sheetnum) {
 List> varList = new ArrayList>();
 String suffix = filename.substring(filename.lastIndexOf(".") + 1);
 if ("xls".equals(suffix)) {
 varList = readExcel2003(filepath, filename, startrow, startcol, sheetnum);
 } else if ("xlsx".equals(suffix)) {
 varList = readExcel2007(filepath, filename, startrow, startcol, sheetnum);
 } else {
 System.out.println("Only excel files with XLS or XLSX suffixes are allowed to be read!");
 return null;
 }
 return varList;
 }
 
 /**
 * 读取2003Excel
 * 
 * @param filepath 文件路径
 * @param filename 文件名,包括扩展名
 * @param startrow 开始行号,索引从0开始
 * @param startcol 开始列号,索引从0开始
 * @param sheetnum 工作簿,索引从0开始
 * @return
 */
 public List> readExcel2003(String filepath, String filename, int startrow, int startcol, int sheetnum) {
 List> varList = new ArrayList>();
 try {
 File target = new File(filepath, filename);
 FileInputStream fis = new FileInputStream(target);
 HSSFWorkbook wb = new HSSFWorkbook(fis);
 fis.close();
 // sheet 从0开始
 HSSFSheet sheet = wb.getSheetAt(sheetnum);
 // 取得最后一行的行号
 int rowNum = sheet.getLastRowNum() + 1;

 HSSFRow rowTitle = sheet.getRow(0);
 // 标题行的最后一个单元格位置
 int cellTitleNum = rowTitle.getLastCellNum();
 String[] title = new String[cellTitleNum];
 for (int i = startcol; i  varpd = new HashMap();
 // 行
 HSSFRow row = sheet.getRow(i);
 // 列循环开始
 for (int j = startcol; j > readExcel2007(String filepath, String filename, int startrow, int startcol, int sheetnum) {
 List> varList = new ArrayList>();
 try {
 File target = new File(filepath, filename);
 InputStream ins = new FileInputStream(target);
 XSSFWorkbook wb = new XSSFWorkbook(ins);
 ins.close();
 // 得到Excel工作表对象
 XSSFSheet sheet = wb.getSheetAt(sheetnum);
 // 取得最后一行的行号
 int rowNum = sheet.getLastRowNum() + 1;

 XSSFRow rowTitle = sheet.getRow(0);
 int cellTitleNum = rowTitle.getLastCellNum();
 String[] title = new String[cellTitleNum];
 for (int i = startcol; i  varpd = new HashMap();
 // 得到Excel工作表的行
 XSSFRow row = sheet.getRow(i);
 // 列循环开始
 for (int j = startcol; j 

读取excel通用工具示例测试类

import java.util.List;
import java.util.Map;

/**
 * @author zql
 *
 */
public class ReadExcelTest {
 
 public static void main(String[] args) throws Exception {
 ReadExcel r = new ReadExcel();
 List> list = r.readExcel("e:\\excel", "测试表格.xls", 0, 0, 0);
 if (list != null) {
 for (int i = 0; i  m = list.get(i);
 m.forEach((key, value) -> {
  System.out.println(key + ":" + value);
 });
 System.out.println();
 }
 }

 List> lists = r.readExcel("e:\\excel", "测试表格.xlsx", 0, 0, 0);
 if (lists != null) {
 for (int i = 0; i  m = lists.get(i);
 m.forEach((key, value) -> {
  System.out.println(key + ":" + value);
 });
 System.out.println();
 }
 }
 }

}

普通项目需要引入的包

poi-4.0.1.jar
poi-ooxml-4.0.1.jar
poi-ooxml-schemas-4.0.1.jar
commons-codec-1.11.jar
commons-collections4-4.3.jar
commons-math3-3.6.1.jar
xmlbeans-3.0.2.jar
commons-compress-1.18.jar
curvesapi-1.06.jar

maven项目依赖



 org.apache.poi
 poi
 4.0.1


 org.apache.poi
 poi-ooxml
 4.0.1

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


推荐阅读
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • Android系统移植与调试之如何修改Android设备状态条上音量加减键在横竖屏切换的时候的显示于隐藏
    本文介绍了如何修改Android设备状态条上音量加减键在横竖屏切换时的显示与隐藏。通过修改系统文件system_bar.xml实现了该功能,并分享了解决思路和经验。 ... [详细]
  • Activiti7流程定义开发笔记
    本文介绍了Activiti7流程定义的开发笔记,包括流程定义的概念、使用activiti-explorer和activiti-eclipse-designer进行建模的方式,以及生成流程图的方法。还介绍了流程定义部署的概念和步骤,包括将bpmn和png文件添加部署到activiti数据库中的方法,以及使用ZIP包进行部署的方式。同时还提到了activiti.cfg.xml文件的作用。 ... [详细]
  • 本文讨论了在shiro java配置中加入Shiro listener后启动失败的问题。作者引入了一系列jar包,并在web.xml中配置了相关内容,但启动后却无法正常运行。文章提供了具体引入的jar包和web.xml的配置内容,并指出可能的错误原因。该问题可能与jar包版本不兼容、web.xml配置错误等有关。 ... [详细]
  • Java如何导入和导出Excel文件的方法和步骤详解
    本文详细介绍了在SpringBoot中使用Java导入和导出Excel文件的方法和步骤,包括添加操作Excel的依赖、自定义注解等。文章还提供了示例代码,并将代码上传至GitHub供访问。 ... [详细]
  • Apache Shiro 身份验证绕过漏洞 (CVE202011989) 详细解析及防范措施
    本文详细解析了Apache Shiro 身份验证绕过漏洞 (CVE202011989) 的原理和影响,并提供了相应的防范措施。Apache Shiro 是一个强大且易用的Java安全框架,常用于执行身份验证、授权、密码和会话管理。在Apache Shiro 1.5.3之前的版本中,与Spring控制器一起使用时,存在特制请求可能导致身份验证绕过的漏洞。本文还介绍了该漏洞的具体细节,并给出了防范该漏洞的建议措施。 ... [详细]
  • Sleuth+zipkin链路追踪SpringCloud微服务的解决方案
    在庞大的微服务群中,随着业务扩展,微服务个数增多,系统调用链路复杂化。Sleuth+zipkin是解决SpringCloud微服务定位和追踪的方案。通过TraceId将不同服务调用的日志串联起来,实现请求链路跟踪。通过Feign调用和Request传递TraceId,将整个调用链路的服务日志归组合并,提供定位和追踪的功能。 ... [详细]
  • 项目运行环境配置及可行性分析
    本文介绍了项目运行环境配置的要求,包括Jdk1.8、Tomcat7.0、Mysql、HBuilderX等工具的使用。同时对项目的技术可行性、操作可行性、经济可行性、时间可行性和法律可行性进行了分析。通过对数据库的设计和功能模块的设计,确保系统的完整性和安全性。在系统登录、系统功能模块、管理员功能模块等方面进行了详细的介绍和展示。最后提供了JAVA毕设帮助、指导、源码分享和调试部署的服务。 ... [详细]
  • Struts2+Sring+Hibernate简单配置
    2019独角兽企业重金招聘Python工程师标准Struts2SpringHibernate搭建全解!Struts2SpringHibernate是J2EE的最 ... [详细]
  • 浅解XXE与Portswigger Web Sec
    XXE与PortswiggerWebSec​相关链接:​博客园​安全脉搏​FreeBuf​XML的全称为XML外部实体注入,在学习的过程中发现有回显的XXE并不多,而 ... [详细]
  • Java使用poi 5.0解析Excel工作簿的例子
    写在之前Excel文档是日常办公中非常普遍的一种数据记录模式。在业务场景中,往往有“导入Excel到某某系统中”的需求,所以这里记录一种使用poi5.0系 ... [详细]
  • 小程序服务器获取用户名头像,微信小程序wx.getUserInfo授权获取用户信息(头像、昵称)的实现...
    这个接口只能获得一些非敏感信息,例如用户昵称,用户头像,经过用户授权允许获取的情况下即可获得用户信息,至于openid这些& ... [详细]
  • 上一章我们设置了分类页面的页面标签,这一章我们继续标签设置格局。话不多说标签设置格局,我们一起操练起来吧~ ... [详细]
  • 本文介绍了使用AJAX的POST请求实现数据修改功能的方法。通过ajax-post技术,可以实现在输入某个id后,通过ajax技术调用post.jsp修改具有该id记录的姓名的值。文章还提到了AJAX的概念和作用,以及使用async参数和open()方法的注意事项。同时强调了不推荐使用async=false的情况,并解释了JavaScript等待服务器响应的机制。 ... [详细]
  • Java序列化对象传给PHP的方法及原理解析
    本文介绍了Java序列化对象传给PHP的方法及原理,包括Java对象传递的方式、序列化的方式、PHP中的序列化用法介绍、Java是否能反序列化PHP的数据、Java序列化的原理以及解决Java序列化中的问题。同时还解释了序列化的概念和作用,以及代码执行序列化所需要的权限。最后指出,序列化会将对象实例的所有字段都进行序列化,使得数据能够被表示为实例的序列化数据,但只有能够解释该格式的代码才能够确定数据的内容。 ... [详细]
author-avatar
HH小娃娃
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有