EasyExcel填充数据EasyExcel填充数据流下载 easyexcel填充excel下载 easyexcel填充

EasyExcel填充数据EasyExcel填充数据流下载 easyexcel填充excel下载 easyexcel填充

1、填充数据然后将文件输出给浏览器

官网地址

官网的demo填充生成的是file文件, 实际需求用的最多的是 填充完数据将Excel输出给浏览器

填充模版Excel文件用的是官方的: 地址: https://github.com/alibaba/easyexcel/blob/master/easyexcel-test/src/test/resources/fill/complex.xlsx

示例代码来自官方的 复杂填充 代码改造,官网地址: https://github.com/alibaba/easyexcel/blob/master/easyexcel-test/src/test/java/com/alibaba/easyexcel/test/demo/fill/FillTest.java

	/*
	* 构建数据
	*/
    private List<FillData> data() {
        List<FillData> list = ListUtils.newArrayList();
        for (int i = 0; i < 10; i++) {
            FillData fillData = new FillData();
            list.add(fillData);
            fillData.setName("张三");
            fillData.setNumber(5.2);
            fillData.setDate(new Date());
        }
        return list;
    }

	public void complex(HttpServletRequest request, HttpServletResponse response) throws ServiceException, IOException {
		
	
		// 把官方 模版下载下来放在  resource资源目录下,获取填充模版文件输入流, 也可以使用 File 对象
	
		InputStream inputStream = Thread.currentThread().getContextClassLoader().getResourceAsStream("excel-templates/tianchong.xlsx");
	
		
		// EasyExcel没有提供填充数据 Excel流下载。需要自己实现
		
		// 创建一个 字节数组输出流,填充数据到字节数组流,然后在输出给浏览器
		ByteArrayOutputStream os = new ByteArrayOutputStream();
	
        
		try (ExcelWriter excelWriter = EasyExcel.write(os).withTemplate(inputStream).build()) {
			
			WriteSheet writeSheet = EasyExcel.writerSheet().build();
			
			// 填充列表数据
			excelWriter.fill(data(), writeSheet);
			
			// 写入list之前的数据
            Map<String, Object> map = MapUtils.newHashMap();
            map.put("date", "2019年10月9日13:28:28");
            map.put("total", 1000);
			
			excelWriter.fill(map, writeSheet);
			
			// 刷新
			excelWriter.finish();
			
			// 这里要额外处理跨域
			response.setHeader("Access-Control-Allow-Origin", "*");
			response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
			response.setCharacterEncoding("utf-8");
			// 这里URLEncoder.encode可以防止中文乱码 当然和easyexcel没有关系
			String fileName = URLEncoder.encode(String.format("填充数据(%s)", LocalDate.now()), "UTF-8").replaceAll("\\+", "%20");
			response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");


			// 直接输出文件
//            response.getOutputStream().write(os.toByteArray());
//            response.getOutputStream().flush();
			
			BufferedOutputStream bufferedOutputStream = new BufferedOutputStream(response.getOutputStream(), 8152);
			bufferedOutputStream.write(os.toByteArray());
			bufferedOutputStream.close();
			
			// 或者使用GZIP压缩输出,但是需要服务器支持
//            OutputStream outputStream = response.getOutputStream();
//            GZIPOutputStream gzipOutputStream = new GZIPOutputStream(outputStream);
//            // 或者
//            DeflaterOutputStream deflaterOutputStream = new DeflaterOutputStream(outputStream);
//            deflaterOutputStream.write(os.toByteArray());
//            deflaterOutputStream.finish();
//            deflaterOutputStream.close();
		
		}
		
	}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值