excel的导入和下载(poi)

通过使用相关的Java库,如Apache POI、EasyPoi或EasyExcel,可以轻松地实现Excel文件的读写操作。

1.2 典型应用场景

  • 报表自动化生成(如导出统计表格)

  • 批量数据导入(如从Excel读取用户信息)

  • 文档模板填充(合同、通知等)

  • 服务器端文档格式转换

  • HSSF/XSSF:处理Excel(97-2003/2007+格式)

  • HWPF/XWPF:处理Word文档

  • HSLF/XSLF:处理PowerPoint

Maven依赖配置

复制代码
<!-- POI核心库 -->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>5.2.3</version>
</dependency>
<!-- 处理xlsx格式 -->
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>5.2.3</version>
</dependency>

创建第一个Excel文件

java 复制代码
import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class ExcelDemo {
    public static void main(String[] args) throws Exception {
        Workbook workbook = new XSSFWorkbook(); // 创建xlsx工作簿
        Sheet sheet = workbook.createSheet("用户列表");
        
        // 创建标题行
        Row headerRow = sheet.createRow(0);
        headerRow.createCell(0).setCellValue("ID");
        headerRow.createCell(1).setCellValue("姓名");
        
        // 添加数据
        Row dataRow = sheet.createRow(1);
        dataRow.createCell(0).setCellValue(1);
        dataRow.createCell(1).setCellValue("张三");
        
        // 保存文件
        try (FileOutputStream fos = new FileOutputStream("demo.xlsx")) {
            workbook.write(fos);
        }
        workbook.close();
    }
}

读取数据

java 复制代码
    public static void read() throws Exception {
 
        // 读取磁盘上面已经存在的Excel文件
        XSSFWorkbook excel = new XSSFWorkbook(new FileInputStream("盘符名:\\***\\123.xlsx"));
 
        // 读取Excel文件里面的第一个sheet页
        XSSFSheet sheet = excel.getSheetAt(0);
 
        // 获取最后一行有数据的文件
        int lastRowNum = sheet.getLastRowNum();
 
        for (int i = 0; i <= lastRowNum; i++) {
            // 获取某一行
            XSSFRow row = sheet.getRow(i);
            String cellValue1 = row.getCell(0).getStringCellValue();
            String cellValue2 = row.getCell(1).getStringCellValue();
            String cellValue3 = row.getCell(2).getStringCellValue();
 
            System.out.println(cellValue1 + "\t" + cellValue2 + "\t" + cellValue3);
        }
 
        // 关闭资源
        excel.close();
 
    }

三、Excel高级操作技巧

java 复制代码
// 创建单元格样式
CellStyle style = workbook.createCellStyle();
style.setFillForegroundColor(IndexedColors.YELLOW.getIndex());
style.setFillPattern(FillPatternType.SOLID_FOREGROUND);

Font font = workbook.createFont();
font.setBold(true);
style.setFont(font);

cell.setCellStyle(style); // 应用样式

合并单元格

java 复制代码
sheet.addMergedRegion(new CellRangeAddress(
    0, // 起始行
    0, // 结束行
    0, // 起始列
    3  // 结束列
));

处理日期与公式

java 复制代码
// 设置日期格式
CellStyle dateStyle = workbook.createCellStyle();
dateStyle.setDataFormat(workbook.createDataFormat().getFormat("yyyy-MM-dd"));
cell.setCellValue(new Date());
cell.setCellStyle(dateStyle);

// 设置公式
cell.setCellFormula("SUM(A1:A10)");
相关推荐
幽络源小助理1 小时前
懒人美食帮SpringBoot订餐系统开发实现
java·spring boot·后端·美食
源码云商3 小时前
基于Spring Boot + Vue的母婴商城系统( 前后端分离)
java·spring boot·后端
还听珊瑚海吗7 小时前
基于SpringBoot的抽奖系统测试报告
java·spring boot·后端
*.✧屠苏隐遥(ノ◕ヮ◕)ノ*.✧10 小时前
MyBatis快速入门——实操
java·spring boot·spring·intellij-idea·mybatis·intellij idea
bing_15812 小时前
Spring MVC 中Model, ModelMap, ModelAndView 之间有什么关系和区别?
java·spring·mvc
杜子腾dd12 小时前
17.Excel:实用的 VBA 自动化程序
数据分析·自动化·excel
曼岛_12 小时前
[Java实战]Spring Boot 静态资源配置(十三)
java·开发语言·spring boot
ABdolphin13 小时前
Spring-博客系统项目
数据库·sql·spring
sco528213 小时前
SpringBoot 自动装配原理 & 自定义一个 starter
java·spring boot·后端
曼岛_13 小时前
[Java实战]Spring Boot 快速配置 HTTPS 并实现 HTTP 自动跳转(八)
java·spring boot·http