java读取简单excel通用工具类

 更新时间:2020年12月31日 10:31:14   作者:似水流年风萧兮  
这篇文章主要为大家详细介绍了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<Map<String,String>> readExcel(String filepath, String filename, int startrow, int startcol, int sheetnum) {
 List<Map<String, String>> varList = new ArrayList<Map<String, String>>();
 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<Map<String,String>> readExcel2003(String filepath, String filename, int startrow, int startcol, int sheetnum) {
 List<Map<String, String>> varList = new ArrayList<Map<String, String>>();
 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 < cellTitleNum; i++) {
 HSSFCell cell = rowTitle.getCell(Short.parseShort(i + ""));
 if (cell != null) {
  cell.setCellType(CellType.STRING);
  title[i] = cell.getStringCellValue();
 } else {
  title[i] = "";
 }
 }

 // 行循环开始
 for (int i = startrow + 1; i < rowNum; i++) {
 Map<String, String> varpd = new HashMap<String, String>();
 // 行
 HSSFRow row = sheet.getRow(i);
 // 列循环开始
 for (int j = startcol; j < cellTitleNum; j++) {

  HSSFCell cell = row.getCell(Short.parseShort(j + ""));
  String cellValue = "";
  if (cell != null) {
  // 把类型先设置为字符串类型
  cell.setCellType(CellType.STRING);
  cellValue = cell.getStringCellValue();
  }
  varpd.put(title[j], cellValue);
 }
 varList.add(varpd);
 }
 wb.close();
 } catch (Exception e) {
 System.out.println(e);
 }
 return varList;
 }
 
 /**
 * 读取2007Excel
 * 
 * @param filepath 文件路径
 * @param filename 文件名,包括扩展名
 * @param startrow 开始行号,索引从0开始
 * @param startcol 开始列号,索引从0开始
 * @param sheetnum 工作簿,索引从0开始
 * @return
 */
 public List<Map<String,String>> readExcel2007(String filepath, String filename, int startrow, int startcol, int sheetnum) {
 List<Map<String, String>> varList = new ArrayList<Map<String, String>>();
 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 < cellTitleNum; i++) {
 XSSFCell cell = rowTitle.getCell(Short.parseShort(i + ""));
 if (cell != null) {
  // 把类型先设置为字符串类型
  cell.setCellType(CellType.STRING);
  title[i] = cell.getStringCellValue();
 } else {
  title[i] = "";
 }
 }

 // 行循环开始
 for (int i = startrow + 1; i < rowNum; i++) {
 Map<String, String> varpd = new HashMap<String, String>();
 // 得到Excel工作表的行
 XSSFRow row = sheet.getRow(i);
 // 列循环开始
 for (int j = startcol; j < cellTitleNum; j++) {
  // 得到Excel工作表指定行的单元格
  XSSFCell cell = row.getCell(j);
  String cellValue = "";
  if (cell != null) {
  // 把类型先设置为字符串类型
  cell.setCellType(CellType.STRING);
  cellValue = cell.getStringCellValue();
  }
  varpd.put(title[j], cellValue);
 }
 varList.add(varpd);
 }
 wb.close();
 } catch (Exception e) {
 System.out.println(e);
 }
 return varList;
 }
 
}

读取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<Map<String, String>> list = r.readExcel("e:\\excel", "测试表格.xls", 0, 0, 0);
 if (list != null) {
 for (int i = 0; i < list.size(); i++) {
 Map<String, String> m = list.get(i);
 m.forEach((key, value) -> {
  System.out.println(key + ":" + value);
 });
 System.out.println();
 }
 }

 List<Map<String, String>> lists = r.readExcel("e:\\excel", "测试表格.xlsx", 0, 0, 0);
 if (lists != null) {
 for (int i = 0; i < lists.size(); i++) {
 Map<String, String> 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项目依赖

<!-- poi -->
<dependency>
 <groupId>org.apache.poi</groupId>
 <artifactId>poi</artifactId>
 <version>4.0.1</version>
</dependency>
<dependency>
 <groupId>org.apache.poi</groupId>
 <artifactId>poi-ooxml</artifactId>
 <version>4.0.1</version>
</dependency>

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

相关文章

  • Java中静态代码块、构造代码块、构造函数和普通代码块的区别

    Java中静态代码块、构造代码块、构造函数和普通代码块的区别

    在Java中,静态代码块、构造代码块、构造函数、普通代码块的执行顺序是一个笔试的考点,通过这篇文章希望大家能彻底了解它们之间的执行顺序,需要的朋友可以参考下
    2023-05-05
  • java实现TCP socket和UDP socket的实例

    java实现TCP socket和UDP socket的实例

    这篇文章主要介绍了本文主要介绍了java实现TCP socket和UDP socket的实例,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • SpringBoot启动原理深入解析

    SpringBoot启动原理深入解析

    我们开发任何一个Spring Boot项目都会用到启动类,下面这篇文章主要给大家介绍了关于SpringBoot启动原理解析的相关资料,文中通过图文以及实例代码介绍的非常详细,需要的朋友可以参考下
    2023-04-04
  • java爬虫之使用HttpClient模拟浏览器发送请求方法详解

    java爬虫之使用HttpClient模拟浏览器发送请求方法详解

    这篇文章主要介绍了java爬虫之使用HttpClient模拟浏览器发送请求方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-07-07
  • java题解LeetCode454.四数相加示例

    java题解LeetCode454.四数相加示例

    这篇文章主要为大家介绍了java题解LeetCode454.四数相加示例思路解析,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-10-10
  • Mybatis Plus select 实现只查询部分字段

    Mybatis Plus select 实现只查询部分字段

    这篇文章主要介绍了Mybatis Plus select 实现只查询部分字段的操作,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2021-09-09
  • Java结合Kotlin实现宝宝年龄计算

    Java结合Kotlin实现宝宝年龄计算

    这篇文章主要为大家介绍了Java结合Kotlin实现宝宝年龄计算示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-06-06
  • 使用注解开发SpringMVC详细配置教程

    使用注解开发SpringMVC详细配置教程

    这篇文章主要介绍了使用注解开发SpringMVC详细配置教程,本文通过图文并茂的形式给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-09-09
  • springboot 按月分表的实现方式

    springboot 按月分表的实现方式

    本文主要介绍了springboot 按月分表的实现方式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2023-04-04
  • 25个最好的免费Eclipse插件

    25个最好的免费Eclipse插件

    这篇文章为大家分享了25个让Java程序员更高效的Eclipse插件,感兴趣的朋友可以参考一下
    2015-12-12

最新评论