当前位置: 首页 > news >正文

东莞网站关键词黄骅市找工作

东莞网站关键词,黄骅市找工作,可信赖的宜昌网站建设,手机wap网站 设计在 Spring Boot 中结合 EasyExcel 实现动态表头导出&#xff08;无实体类&#xff0c;表头和字段&#xff08;前端传表名&#xff0c;字段值动态查询&#xff0c;返回List<Map<String,Object>>&#xff09;由前端传递&#xff09;可以通过以下步骤实现。以下是完整…

在 Spring Boot 中结合 EasyExcel 实现动态表头导出(无实体类,表头和字段(前端传表名,字段值动态查询,返回List<Map<String,Object>>)由前端传递)可以通过以下步骤实现。以下是完整示例:


1. 前端请求数据结构

假设前端传递的 JSON 格式如下:

{"headers": [{"title": "姓名", "field": "name"},{"title": "年龄", "field": "age"},{"title": "城市", "field": "city"}],"data": [{"name": "张三", "age": 25, "city": "北京"},{"name": "李四", "age": 30, "city": "上海"}]
}

2. 后端 DTO 定义

定义接收参数的 DTO 类:

@Data
public class ExportRequest {private List<Header> headers;private List<Map<String, Object>> data;@Datapublic static class Header {private String title;  // 表头名称private String field;  // 数据字段名}
}

3. Controller 层接口

处理导出请求:

@RestController
public class ExportController {@Autowiredprivate ExportService exportService;@PostMapping("/export")public void exportExcel(@RequestBody ExportRequest request, HttpServletResponse response) {exportService.export(request, response);}
}

4. Service 层实现

核心导出逻辑:

@Service
public class ExportService {public void export(ExportRequest request, HttpServletResponse response) {try {// 设置响应头response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");response.setCharacterEncoding("UTF-8");String fileName = URLEncoder.encode("动态导出.xlsx", "UTF-8");response.setHeader("Content-Disposition", "attachment; filename=" + fileName);// 获取输出流OutputStream outputStream = response.getOutputStream();// 动态构建表头和数据WriteSheet writeSheet = EasyExcel.writerSheet("Sheet1").build();ExcelWriter excelWriter = EasyExcel.write(outputStream).build();// 动态添加表头WriteTable writeTable = new WriteTable();List<List<String>> head = buildHead(request.getHeaders());writeTable.setHead(head);// 动态填充数据List<List<Object>> data = buildData(request.getHeaders(), request.getData());excelWriter.write(data, writeSheet, writeTable);// 关闭流excelWriter.finish();outputStream.flush();} catch (IOException e) {throw new RuntimeException("导出失败", e);}}// 构建表头private List<List<String>> buildHead(List<ExportRequest.Header> headers) {List<List<String>> head = new ArrayList<>();for (ExportRequest.Header header : headers) {List<String> columnHead = Collections.singletonList(header.getTitle());head.add(columnHead);}return head;}// 构建数据行private List<List<Object>> buildData(List<ExportRequest.Header> headers, List<Map<String, Object>> dataList) {List<List<Object>> data = new ArrayList<>();for (Map<String, Object> rowData : dataList) {List<Object> row = new ArrayList<>();for (ExportRequest.Header header : headers) {row.add(rowData.get(header.getField()));}data.add(row);}return data;}
}

5. 关键点说明

  1. 动态表头

    • 通过 buildHead() 方法将前端传递的 headers 转换为 EasyExcel 需要的 List<List<String>> 格式。
  2. 动态数据

    • 通过 buildData() 方法,根据 headers 中定义的 field 字段顺序,从 data 中提取对应值,构建数据行。
  3. 流式导出

    • 使用 ExcelWriter 直接操作输出流,避免内存溢出(适合大数据量)。

6. 测试与验证

使用 Postman 发送请求:

  • URL: POST http://localhost:8080/export

  • Body(JSON):

    {"headers": [{"title": "姓名", "field": "name"},{"title": "年龄", "field": "age"},{"title": "城市", "field": "city"}],"data": [{"name": "张三", "age": 25, "city": "北京"},{"name": "李四", "age": 30, "city": "上海"}]
    }
    
  • 响应:浏览器自动下载 动态导出.xlsx,内容如下:

    姓名年龄城市
    张三25北京
    李四30上海

7. 扩展优化

  • 字段校验:确保前端传递的 fielddata 中存在对应值。
  • 大数据量分页:如果数据量过大,可分页查询后分批写入。
  • 自定义样式:通过 WriteHandler 动态设置单元格样式(如字体、颜色)。

通过这种方式,无需定义实体类即可实现完全动态的 Excel 导出功能,表头和字段完全由前端控制。

http://www.yayakq.cn/news/102265/

相关文章:

  • 网站首页建设中页面液压电机东莞网站建设
  • 优秀电商网站小企业财务软件免费版
  • 网站备案账号密码wd设计视图可以做网站吗
  • 网站建设设计说明书北京房产网官网
  • 15年做啥网站致富站群服务器是什么意思
  • 如何给网站做地图seo优化自学
  • 学做标书网站有哪些网站可以做推文
  • 精品课程网站建设内容推广seo主管招聘
  • 局域网搭建工具sem优化
  • win7做系统网站哪个好用ipad写wordpress
  • 婴儿辅食中企动力提供网站建设企业网站建设的一般要素主要包括网站的
  • 微信网站开发简单《网站开发与应用》大作业
  • 空间中国网站正规网站建设公司哪个比较好
  • 怎样学做网站网站建设合作协议模板
  • 小程序网站开发公司wordpress奇客影院
  • 河源公司做网站视频网站闪图怎么做
  • 源码网站违法吗江苏商城网站建设服务
  • 如何不花钱开发网站线上做图的网站
  • 商城网站支付系统怎么做多城市网站开发
  • 阿里巴巴国际站下载高端的网站设计费用
  • wordpress网站备份恢复音乐网站开发模板
  • 杭州公司网站建设套餐镇江润州区建设局网站
  • 营销型企业网站分免费咨询法律援助该打什么电话
  • 百度资料怎么做网站wordpress 移动社交主题
  • 中国建设招标网官方网站网站建设与实践步骤
  • 网站建设公司的市场定位免费空间是什么意思
  • app公司网站建设价格手机app定制开发公司
  • 法治与安全做讲座网站通化公司做网站
  • 做纺织的都用什么网站seo优化知识
  • 做教师知识网站有哪些网速