温馨提示×

java中怎么用poi导出excel数据

小亿
85
2024-01-18 12:52:06
栏目: 编程语言

使用POI库可以在Java中导出Excel数据。以下是一个示例代码,可以将数据导出到Excel文件中:

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

import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

public class ExcelExporter {
    public static void main(String[] args) {
        // 创建数据列表
        List<Person> personList = new ArrayList<>();
        personList.add(new Person("John", 25));
        personList.add(new Person("Jane", 30));
        personList.add(new Person("David", 35));

        // 创建工作簿
        Workbook workbook = new XSSFWorkbook();

        // 创建表格
        Sheet sheet = workbook.createSheet("Person Data");

        // 创建表头
        Row header = sheet.createRow(0);
        header.createCell(0).setCellValue("Name");
        header.createCell(1).setCellValue("Age");

        // 创建数据行
        int rowNum = 1;
        for (Person person : personList) {
            Row row = sheet.createRow(rowNum++);
            row.createCell(0).setCellValue(person.getName());
            row.createCell(1).setCellValue(person.getAge());
        }

        // 调整列宽度
        sheet.autoSizeColumn(0);
        sheet.autoSizeColumn(1);

        // 保存文件
        try (FileOutputStream outputStream = new FileOutputStream("person_data.xlsx")) {
            workbook.write(outputStream);
        } catch (IOException e) {
            e.printStackTrace();
        }

        System.out.println("Excel文件导出成功!");
    }

    // 定义数据模型
    private static class Person {
        private String name;
        private int age;

        public Person(String name, int age) {
            this.name = name;
            this.age = age;
        }

        public String getName() {
            return name;
        }

        public int getAge() {
            return age;
        }
    }
}

这个例子中,我们使用了XSSFWorkbook类创建了一个新的工作簿,然后创建了一个名为"Person Data"的表格。我们使用createRow()方法创建了表头和数据行,并使用setCellValue()方法设置单元格的值。最后,我们使用FileOutputStream将工作簿写入到文件中。

请注意,这个例子中使用了XSSFWorkbook类,这意味着导出的Excel文件是.xlsx格式的。如果你需要导出为.xls格式的文件,可以使用HSSFWorkbook类来创建工作簿。

0