jfinal之使用模板导出excel文件

3 篇文章 0 订阅

本文使用java Jfinal快速框架,使用模板导出excel文件:

主要代码如下:

    public void toExcel() throws IOException, InvalidFormatException {
        SimpleDateFormat time = new SimpleDateFormat("yyyy年");
        String fileName = time.format(new Date())+"母猪保险分户标的投保清单";
        String filePath = PathKit.getWebRootPath() + File.separator + "download" + File.separator + fileName+ ".xlsx";
        //excel模板路径  
        File fi = new File(PathKit.getWebRootPath() + File.separator + "tpl" + File.separator + "模板.xlsx");
        //读取excel模板  
        XSSFWorkbook wb = new XSSFWorkbook(fi);
        //读取了模板内所有sheet内容  
        XSSFSheet sheet = wb.getSheet("投保清单模板");
        //在相应的单元格进行赋值  
        XSSFCell title_cell = sheet.getRow(0).getCell(0);
        title_cell.setCellValue(fileName);
//        college_sheet.addMergedRegion(new CellRangeAddress(9,(short)9,5,(short)11));//指定合并区域
//        XSSFCell semester_name_cell = college_sheet.getRow(9).getCell(5);
        XSSFRow row;
        for (int i=0;i< 10;i++) {
            row = sheet.createRow(i+3);
            // 第四步,创建单元格,并设置值  
            row.createCell((short)0).setCellValue("第"+i+"行第一列数据");  
            row.createCell((short)1).setCellValue("第"+i+"行第二列数据");  
            row.createCell((short)2).setCellValue("第"+i+"行第三列数据");   
        }
        try ( //修改模板内容导出新模板
            FileOutputStream out = new FileOutputStream(filePath)) {
            wb.write(out);
            renderFile(new File(filePath));//导出excel
        } catch (Exception e) {
            e.getMessage();
        }
    }


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Java EasyExcel提供了一种更加灵活的方式来导出Excel数据,可以使用EasyExcel提供的SAX模式来实现一对多导出。 SAX是一种流式数据处理方式,它的处理方式是在解析XML文档时,读取一段数据并立即处理,然后继续读取下一段数据,从而实现对大型XML文档的高效处理。 EasyExcel提供了SAX模式,可以将大量数据写入Excel,并且不会出现内存溢出等问题。在使用SAX模式时,需要实现一个WriteHandler接口,并在其中实现对Excel数据的处理逻辑。 下面是一个示例代码,实现了一对多导出Excel数据,不使用对象: ```java public class ExcelWriterHandler implements WriteHandler { private final List<List<String>> dataList; public ExcelWriterHandler(List<List<String>> dataList) { this.dataList = dataList; } @Override public void sheet(int sheetNo, Sheet sheet) { } @Override public void row(int rowNum, Row row) { List<String> rowData = dataList.get(rowNum); for (int i = 0; i < rowData.size(); i++) { Cell cell = row.createCell(i); cell.setCellValue(rowData.get(i)); } } @Override public void cell(int cellNum, Cell cell) { } } ``` 在这个示例代码中,我们实现了WriteHandler接口,并在其中实现了对Excel数据的处理逻辑。在row方法中,我们根据当前行号获取对应的一行数据,并将数据写入到Excel中。 接下来,我们可以使用EasyExcel的SAX模式来将数据写入Excel文件中: ```java public class ExcelExporter { public static void export(String filePath, List<List<String>> dataList) throws IOException { try (OutputStream out = new FileOutputStream(filePath)) { ExcelWriterBuilder builder = EasyExcel.write(out); WriteSheet sheet = builder.sheet().build(); builder.registerWriteHandler(new ExcelWriterHandler(dataList)).build(); builder.doWrite(dataList); } } } ``` 在这个示例代码中,我们首先创建了一个ExcelWriterBuilder对象,并注册了一个ExcelWriterHandler对象。然后,我们调用doWrite方法将数据写入Excel文件中。 最后,我们可以调用ExcelExporter.export方法来实现一对多导出Excel数据: ```java public class Main { public static void main(String[] args) throws IOException { List<List<String>> dataList = new ArrayList<>(); List<String> header = Arrays.asList("姓名", "年龄", "性别"); List<String> row1 = Arrays.asList("张三", "20", "男"); List<String> row2 = Arrays.asList("李四", "22", "女"); dataList.add(header); dataList.add(row1); dataList.add(row2); ExcelExporter.export("test.xlsx", dataList); } } ``` 这个示例代码实现了一个简单的一对多导出Excel数据的功能。你可以根据自己的需求来修改代码,并实现更加复杂的Excel导出功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

生命无须向死而生

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

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

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

打赏作者

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

抵扣说明:

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

余额充值