使用XSSFWorkbook生成Excel后保存到服务器中

生成Excel部分

XSSFWorkbook workbook = XSSFWorkbookFactory.createWorkbook();       //创建Excel表

        XSSFSheet sheet = workbook.createSheet("Sheet名");             //创建sheet
        //设置第一行标题行的宽度
        sheet.setColumnWidth(1, 252 * 15 + 600);        
        sheet.setColumnWidth(2,252 * 30 + 323);         
        sheet.setColumnWidth(3, 252 * 30 + 323);       
        sheet.setColumnWidth(4, 252 * 50 + 323);        
        sheet.setColumnWidth(5, 252 * 15 + 323);       
        sheet.setColumnWidth(6, 252 * 17 + 650);        
        sheet.setColumnWidth(7, 252 * 16 + 323);      

        //固定第一行的标题内容
        XSSFRow row = sheet.createRow(0);
        row.createCell(0).setCellValue("001");
        row.createCell(1).setCellValue("002");
        row.createCell(2).setCellValue("003");
        row.createCell(3).setCellValue("004");
        row.createCell(4).setCellValue("005");
        row.createCell(5).setCellValue("006");
        row.createCell(6).setCellValue("007");
    保存Excel到服务器的固定路径中
String projectName=projectDao.findById(projectId).get().getName();
        String date = LocalDateTime.now().format(DateTimeFormatter.ofPattern("yyyyMMddHHmmss"));
        String fileName=projectName+addFileName+date+".xlsx";

        String path="/static/excel/";
        String Dir = request.getServletContext().getRealPath(path);
        //判断文件夹是否存在
        File parent = new File(Dir);
        if (!parent.exists()) {
            parent.mkdirs();
        }
        File file=new File(Dir,fileName);
        OutputStream os=new FileOutputStream(file);
        workbook.write(os);
        os.flush();
        os.close();
  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
好的,针对您的问题,我可以给您提供一些思路。 首先,您可以使用POI这个Java库来生成Excel文件。POI提供了一系列的API来创建、修改和读取Excel文件。您可以通过POI来创建一个工作簿,然后在工作簿创建一个工作表,接着设置工作表的表头,合并单元格等。 其次,您需要将数据循环读取出来,然后按照您的需求填充到Excel文件。您可以通过POI提供的API来设置单元格的值、样式等。在填充数据的过程,根据您的需求来进行合并单元格,可以使用CellRangeAddress类来设置需要合并的单元格。 最后,将生成Excel文件写入到输出流,这样就可以将Excel文件输出到客户端或者保存服务器了。 下面是一个简单的示例代码,仅供参考: ```java // 创建工作簿 Workbook workbook = new XSSFWorkbook(); // 创建工作表 Sheet sheet = workbook.createSheet("Sheet1"); // 设置表头 Row headerRow = sheet.createRow(0); Cell headerCell = headerRow.createCell(0); headerCell.setCellValue("表头"); // 合并单元格 CellRangeAddress region = new CellRangeAddress(0, 0, 0, 3); sheet.addMergedRegion(region); // 填充数据 for (int i = 0; i < dataList.size(); i++) { Row dataRow = sheet.createRow(i + 1); // 设置单元格的值 dataRow.createCell(0).setCellValue(dataList.get(i).getName()); dataRow.createCell(1).setCellValue(dataList.get(i).getAge()); dataRow.createCell(2).setCellValue(dataList.get(i).getGender()); dataRow.createCell(3).setCellValue(dataList.get(i).getAddress()); } // 将Excel文件写入输出流 ServletOutputStream outputStream = response.getOutputStream(); workbook.write(outputStream); outputStream.flush(); outputStream.close(); ``` 当然,这只是一个简单的示例代码,您需要根据实际需求来进行更加详细的实现。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

HolmesW

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值