Java生成Excel并套用模板

在日常工作或者项目开发中,我们经常需要将数据导出为Excel文件,以便于数据的整理、分析或者展示。Java提供了一些强大的开源库,如Apache POI,可以帮助我们生成Excel文件。同时,为了使生成的Excel文件更加美观和规范,我们可以使用模板来定义格式和样式。

本文将介绍如何使用Java生成Excel文件并套用模板。首先,我们需要导入Apache POI相关的依赖。

<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>4.1.2</version>
</dependency>

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

接下来,我们需要创建一个工作簿(Workbook)对象,该对象表示整个Excel文件。

import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class ExcelGenerator {
    public static void main(String[] args) {
        Workbook workbook = new XSSFWorkbook();
        
        // 创建工作表
        Sheet sheet = workbook.createSheet("Sheet1");
        
        // 创建行
        Row row = sheet.createRow(0);
        
        // 创建单元格,并设置值
        Cell cell = row.createCell(0);
        cell.setCellValue("Hello, World!");
        
        // 保存Excel文件
        try (FileOutputStream outputStream = new FileOutputStream("output.xlsx")) {
            workbook.write(outputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

上述代码创建了一个工作簿对象,并在该工作簿中创建了一个名为“Sheet1”的工作表。然后,创建了一个单元格,并在该单元格中设置了值“Hello, World!”。最后,通过指定文件输出流将工作簿写入到名为“output.xlsx”的Excel文件中。

生成的Excel文件可能还不够美观或者缺少一些自定义的格式。这时,我们可以通过模板来定义Excel的格式和样式。

import org.apache.poi.ss.usermodel.*;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

public class ExcelGenerator {
    public static void main(String[] args) {
        Workbook workbook = new XSSFWorkbook();
        
        // 创建工作表
        Sheet sheet = workbook.createSheet("Sheet1");
        
        // 加载模板
        try (InputStream template = ExcelGenerator.class.getResourceAsStream("template.xlsx")) {
            workbook = WorkbookFactory.create(template);
        } catch (IOException e) {
            e.printStackTrace();
        }
        
        // 获取工作表
        sheet = workbook.getSheet("Sheet1");
        
        // 创建行
        Row row = sheet.createRow(0);
        
        // 创建单元格,并设置值
        Cell cell = row.createCell(0);
        cell.setCellValue("Hello, World!");
        
        // 保存Excel文件
        try (FileOutputStream outputStream = new FileOutputStream("output.xlsx")) {
            workbook.write(outputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }
    }
}

上述代码中,我们通过getResourceAsStream方法从类路径中加载了一个名为“template.xlsx”的模板文件。然后,使用WorkbookFactory.create方法将模板文件转换为工作簿对象。接下来,我们获取了工作表并继续对工作表进行操作,如创建行和单元格,并设置值。最后,将工作簿写入到Excel文件中。

通过以上代码,我们可以生成一个带有模板的Excel文件,该文件已经包含了预定义的格式和样式。我们可以根据实际需求对模板文件进行设计,包括设置字体、颜色、边框等。

总结一下,本文介绍了如何使用Java生成Excel文件并套用模板。通过使用Apache POI库,我们可以方便地创建和操作Excel文件。同时,使用模板可以使生成的Excel文件更加美观和规范。希望本文对你理解Java生成Excel并套用模板有所帮助。

参考代码:

  • 完整代码示例可参考[Github](