java easyexcel导出字段可选

使用easyexcel进行导出时根据前端传入的导出字段进行自定义导出

Controller层
@PostMapping("/export") public void export(@RequestBody DemoVo demolVo,HttpServletResponse response) throws IOException { demoService.exportExcel(demoVo,response); }

ServiceImpl实现层

--下载到浏览器
@Override
public void exportExcel(DemoVo demolVo, HttpServletResponse response) throws IOException {

    //数据查询返回封装list

     ObjectMapper mapper = new ObjectMapper();
	//JAVA类转化为String类型键值对
	String json = mapper.writeValueAsString(demolVo);
	//String转化为json
	JSONObject jsonObject= JSONObject.parseObject(json);
	//获得json所有键
	Set<String> keys = jsonObject.keySet();
	//遍历获取所有值(用户传入的字段),并存入集合
	Set<String> column = new HashSet<String>();
	for (String key : keys) {
		if (jsonObject.get(key) != null){
			column.add(jsonObject.get(key).toString());
		}
	}

	String fileName="output.xlsx";
	//设置响应头,文件名和文件类型
	response.setHeader("content-disposition","attachment;filename="+ URLEncoder.encode(fileName,"utf-8"));
	response.setContentType("application/octet-stream");
	//这里 需要指定写用哪个class去写,然后写到第一个sheet,名字为模板 然后文件流会自动关闭
	EasyExcel.write(response.getOutputStream(), DemoVo.class)
			.includeColumnFiledNames(column).sheet("模板")
			.doWrite(list);
	//刷新输出流并关闲
	response.flushBuffer();
}


--下载到指定目录
@Override
public void exportExcel(DemoVo demolVo) throws IOException {

    //数据查询返回封装list

     ObjectMapper mapper = new ObjectMapper();
	//JAVA类转化为String类型键值对
	String json = mapper.writeValueAsString(demolVo);
	//String转化为json
	JSONObject jsonObject= JSONObject.parseObject(json);
	//获得json所有键
	Set<String> keys = jsonObject.keySet();
	//遍历获取所有值(用户传入的字段),并存入集合
	Set<String> column = new HashSet<String>();
	for (String key : keys) {
		if (jsonObject.get(key) != null){
			column.add(jsonObject.get(key).toString());
		}
	}
   //这里 需要指定写用哪个class去写,然后写到第一个sheet,名字为模板 然后文件流会自动关闭
	File filepath=new File("E:/excel");
	if(!filepath.exists()){
		filepath.mkdirs();
	}
	EasyExcel.write("E:\\excel\\output.xlsx", DemoVo .class)
			.includeColumnFiledNames(column).sheet("模板")
			.doWrite(list);
   }
posted @ 2024-01-24 16:10  食来运转  阅读(388)  评论(0)    收藏  举报