Java通过Apache POI操作Excel

1、添加依赖

xml 复制代码
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi</artifactId>
            <version>3.9</version>
        </dependency>
        <dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>3.9</version>
        </dependency>
        <dependency>
            <groupId>joda-time</groupId>
            <artifactId>joda-time</artifactId>
            <version>2.10.1</version>
        </dependency>

2、读 EXCEL

java 复制代码
	public static void read() throws Exception{
        FileInputStream stream = new FileInputStream("D:\\Test\\file.xlsx");
        // 1.创建工作簿对象,并指定操作的文件
        Workbook workbook = new XSSFWorkbook(stream);
        // 2.获取工作表对象,既可以根据工作表的顺序获取,也可以根据工作表的名称获取
        Sheet sheet = workbook.getSheet("Sheet0");
        // 获取行数(获取当前工作表最后一行的行号,行号从0开始)
        int lastRowNum = sheet.getLastRowNum();
        // 获取列数
        Row row1 = sheet.getRow(0);
        int colNum = row1.getPhysicalNumberOfCells();
        // 3.遍历工作表获得行对象
        for(int i=0; i<=lastRowNum;i++){
            Row row = sheet.getRow(i);
            for (int j = 0; j < colNum; j++) {
                Cell cell = row.getCell(j);
                // 处理数字值
                if (cell.getCellType() == CellType.NUMERIC) {
                    double numericValue = cell.getNumericCellValue();
                    System.out.println(numericValue);
                } else if (cell.getCellType() == CellType.STRING) {
                    // 处理字符串值
                    String stringValue = cell.getStringCellValue();
                    System.out.println(stringValue);
                }
            }
        }
    }

注意:

1、操作的 EXCEL 对象要区分 .xls文件 还是 .xlsx 文件

java 复制代码
   FileInputStream stream = new FileInputStream("D:\\Test\\file.xlsx");
 	// XSSF操作的是Excel2007以上的版本,对应文件的后缀名是xlsx 
   Workbook workbook = new XSSFWorkbook(inputStream)  
 	// HSSF操作的是Excel2003以前的版本,对应的文件后缀名是xls
   Workbook workbook = new HSSFWorkbook(inputStream)

2、读取单元格数据要注意数据格式

读取单元格数据之前,可以先检查该单元格的数据类型。如果它是数字类型,那么你应该读取它的数值值;如果它是文本类型,那么你应该读取它的字符串值。这样可以避免数据类型不匹配的问题。

java 复制代码
 Cell cell = row.getCell(columnIndex);   
  // 处理数字值    } 
 if(cell.getCellType() == CellType.NUMERIC) {
   	double numericValue = cell.getNumericCellValue();
  // 处理字符串值   
 else if (cell.getCellType() == CellType.STRING) {
    String stringValue = cell.getStringCellValue();
  } 

2、写 EXCEL

java 复制代码
    public static void write(Workbook workbook,String path) throws Exception {
        /*创建一个表*/
        Sheet sheet = workbook.createSheet("Sheet1");
        /*创建一行*/
        Row row1 = sheet.createRow(0);
        /*创建一个单元格*/
        Cell cell = row1.createCell(0);
        /*设置单元格的内容*/
        cell.setCellValue("学习的内容");
        cell = row1.createCell(1);
        cell.setCellValue("java操作ecxel");
        Row row2 = sheet.createRow(1);
        cell = row2.createCell(0);
        cell.setCellValue("学习的时间");
        cell = row2.createCell(1);
        cell.setCellValue("2025-03-14 15:35:26");
        FileOutputStream fileOutputStream = new FileOutputStream(path);
        workbook.write(fileOutputStream);
        fileOutputStream.flush();
        fileOutputStream.close();
    }

3、主程序调用

java 复制代码
    public static void main(String[] args) throws Exception {
        Workbook workbook = new XSSFWorkbook();//xlsx
        write(workbook,"D:\\Test\\file.xlsx");
        read();
    }
相关推荐
Sayuanni%3几秒前
初阶_多线程1(线程含义与关键属性)
java
程序媛徐师姐1 分钟前
Java基于微信小程序的模拟考试系统,附源码+文档说明
java·微信小程序·java模拟考试系统小程序·模拟考试微信小程序·模拟考试系统小程序·模拟考试小程序·java模拟考试小程序
疯狂敲代码的老刘10 分钟前
JDK 1.6到25 全版本网盘合集 (Windows + Mac + Linux)
java·linux·windows·macos·jdk
夕除12 分钟前
js--15
java·jvm·spring
曾经的三心草17 分钟前
redis-9-集群
java·redis·mybatis
sun032222 分钟前
【架构基础】Spring中的PropertySourcesPlaceholderConfigurer介绍 (并非新知识,比较古老的一种使用方式)
java·spring·架构
chilavert31824 分钟前
技术演进中的开发沉思-356:重排序(中)
java·开发语言
毕设源码-邱学长25 分钟前
【开题答辩全过程】以 基于SSM的儿童福利院管理系统为例,包含答辩的问题和答案
java·eclipse
TT哇31 分钟前
【实习】数字营销系统 银行经理端(interact_bank)前端 Vue 移动端页面的 UI 重构与优化
java·前端·vue.js·ui
Elieal41 分钟前
SpringBoot 数据层开发与企业信息管理系统实战
java·spring boot·后端