springboot poi 3 导入导出Excel记录

一:依赖

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

二:导入

@GetMapping("/importXlsx")
public void importXlsx() throws Exception {
    String path = "C:\\Users\\Administrator\\Desktop\\tycyerr";//路径
    File fileDir = new File(path);//读取文件夹
    File[] files = fileDir.listFiles();
    System.err.println("文件数量" + files.length);
    for (int f = 0; f < files.length; f++) {
        String name = files[f].getName();
        System.out.println(name);
        if (name.endsWith(".xlsx")) {
            FileInputStream in = new FileInputStream(new File(path+"\\" + name));
            XSSFWorkbook workbook = new XSSFWorkbook(in);
            XSSFSheet sheet = null;
            //for (int i = 0; i < workbook.getNumberOfSheets(); i++) {// 获取每个Sheet表
            sheet = workbook.getSheetAt(0);//获取第一个sheet
            System.err.println("行数" + sheet.getLastRowNum());
for (int j = 0; j < sheet.getPhysicalNumberOfRows(); j++) {// 获取每行
    XSSFRow row = sheet.getRow(j);
    for (int k = 1; k < row.getPhysicalNumberOfCells(); k++) {// 获取每个单元格
        XSSFCell cell = row.getCell(k);
        if (null != cell) {
           cell.setCellType(CellType.STRING);
           String value=cell.getStringCellValue().trim()
        }
    }
}

}

三:导出

public CommonResult selectWork(String year, String month, Integer unitId, HttpServletResponse response) {
    XSSFWorkbook workbook = new XSSFWorkbook();//创建excel
    XSSFSheet sheet = workbook.createSheet("自主择业一次性补贴汇总表");//创建sheet
    Map<String, Object> param = new HashMap<>();//将来要获取的数据
    //第一行
    XSSFRow row = sheet.createRow(0);//创建第1行
    XSSFCell cell = row.createCell(0);//创建第一行的第一列
    cell.setCellValue("附件11");//第一行第一列设置值
    CellRangeAddress region = new CellRangeAddress(0, 0, 0, 26);//合并单元格
    sheet.addMergedRegion(region);

       

//导出到本地
try {
    FileOutputStream fileOutputStream = new FileOutputStream("D:\\img\\test单元格.xlsx");
    workbook.write(fileOutputStream);
    fileOutputStream.close();
} catch (Exception e) {
    e.printStackTrace();
}
//显示到页面下载
try {
    String fileName = "test" + new SimpleDateFormat("yyyyMMddHHmmss").format(new Date());
    fileName = URLEncoder.encode(fileName, "UTF8");
    response.setContentType("application/vnd.ms-excel;chartset=utf-8");
    response.setHeader("Content-Disposition", "attachment;filename=" + fileName + ".xls");
    ServletOutputStream out = response.getOutputStream();
    workbook.write(out);
    out.flush();
    out.close();
} catch (
        Exception e) {
    e.printStackTrace();
}

总结:总是记不住,写下来记录一下

 

Spring Boot是一个基于Spring框架的快速开发框架,而POI是一个Java处理Microsoft Office格式文件的开源库。通过结合Spring Boot和POI,我们可以实现Excel文件的导入导出功能。 在Spring Boot中使用POI进行Excel文件导入导出,需要先添加POI的依赖。在pom.xml文件中添加以下依赖: ``` <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> ``` 接下来,我们可以使用POI提供的API来实现Excel文件的导入导出。具体实现方式可以参考以下代码: Excel文件导入: ``` public List<User> importExcel(MultipartFile file) throws IOException { List<User> userList = new ArrayList<>(); Workbook workbook = WorkbookFactory.create(file.getInputStream()); Sheet sheet = workbook.getSheetAt(); for (int i = 1; i <= sheet.getLastRowNum(); i++) { Row row = sheet.getRow(i); User user = new User(); user.setName(row.getCell().getStringCellValue()); user.setAge((int) row.getCell(1).getNumericCellValue()); user.setGender(row.getCell(2).getStringCellValue()); userList.add(user); } return userList; } ``` Excel文件导出: ``` public void exportExcel(List<User> userList, HttpServletResponse response) throws IOException { Workbook workbook = new XSSFWorkbook(); Sheet sheet = workbook.createSheet("用户列表"); Row headerRow = sheet.createRow(); headerRow.createCell().setCellValue("姓名"); headerRow.createCell(1).setCellValue("年龄"); headerRow.createCell(2).setCellValue("性别"); for (int i = ; i < userList.size(); i++) { Row row = sheet.createRow(i + 1); row.createCell().setCellValue(userList.get(i).getName()); row.createCell(1).setCellValue(userList.get(i).getAge()); row.createCell(2).setCellValue(userList.get(i).getGender()); } response.setContentType("application/vnd.ms-excel"); response.setHeader("Content-disposition", "attachment;filename=userList.xlsx"); workbook.write(response.getOutputStream()); } ``` 以上代码实现了一个简单的Excel文件导入导出功能。在实际开发中,我们可以根据具体需求进行修改和扩展。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值