springMVC 导出Excel ,并提供下载(处理日期格式问题)

 

目录

1、POI的三个依赖

2、控制层代码

3、业务层代码

4、参考文献:


 

1、POI的三个依赖

<!-- POI的三个依赖 --><dependency><groupId>org.apache.poi</groupId><artifactId>poi</artifactId><version>4.1.2</version></dependency><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml-schemas</artifactId><version>4.1.2</version></dependency><!-- https://mvnrepository.com/artifact/org.apache.poi/poi-ooxml --><dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>4.1.2</version></dependency>

2、控制层代码

@RequestMapping("/exportExcel.ctrl")@ResponseBodyResponseEntity<byte[]> exportExcel(PlcFirst record) throws UnsupportedEncodingException {return plcFirstService.exportExcel(record);}

3、业务层代码

    public ResponseEntity<byte[]> exportExcel(PlcFirst record) throws UnsupportedEncodingException {//1、 根据条件查询需要的数据List<PlcFirst> list = plcFirstMapper.selectPage2(record);//2、创建一个excel并写入内容HSSFWorkbook workbook=new HSSFWorkbook();HSSFSheet sheet=workbook.createSheet("Sheet1");//3、填写表头HSSFRow row=sheet.createRow(0);HSSFCell cell=row.createCell(0);cell.setCellValue("序列号");HSSFCell cell1=row.createCell(1);cell1.setCellValue("工序号");HSSFCell cell2=row.createCell(2);cell2.setCellValue("扭矩");HSSFCell cell3=row.createCell(3);cell3.setCellValue("角度");HSSFCell cell4=row.createCell(4);cell4.setCellValue("OK/NG");HSSFCell cell5=row.createCell(5);cell5.setCellValue("工具号");HSSFCell cell6=row.createCell(6);cell6.setCellValue("打印码");HSSFCell cell7=row.createCell(7);cell7.setCellValue("创建时间");// 创建日期格式的单元格格式DataFormat dataFormat = workbook.createDataFormat();CellStyle cellStyle = workbook.createCellStyle();cellStyle.setDataFormat(dataFormat.getFormat("yyyy-MM-dd HH:mm:ss"));// 4、遍历数据,并写入Excel。int i=1;for (PlcFirst plc : list) {HSSFRow rowi = sheet.createRow(i++);rowi.createCell(0).setCellValue(plc.getSerNo());rowi.createCell(1).setCellValue(plc.getGongXuHao());rowi.createCell(2).setCellValue(plc.getNiuJu());rowi.createCell(3).setCellValue(plc.getJiaoDu());rowi.createCell(4).setCellValue(plc.getOkNg());rowi.createCell(5).setCellValue(plc.getGongJuHao());rowi.createCell(6).setCellValue(plc.getDaYinMa());HSSFCell cell77 = rowi.createCell(7);cell77.setCellValue(plc.getCreateTime());// 设置单元格格式为日期格式cell77.setCellStyle(cellStyle);}// EEEEE//创建一个字节数组输出流对象ByteArrayOutputStream outputStream=new ByteArrayOutputStream();try {//将excel写入输出流workbook.write(outputStream);workbook.close();} catch (IOException e) {e.printStackTrace();}HttpHeaders headers=new HttpHeaders();String fileName=new String("excel.xls".getBytes("UTF-8"),"iso-8859-1");headers.setContentDispositionFormData("attachment", fileName);headers.setContentType(MediaType.APPLICATION_OCTET_STREAM);ResponseEntity<byte[]> returnFile=new ResponseEntity<byte[]>(outputStream.toByteArray(),headers,HttpStatus.CREATED);try {outputStream.close();} catch (IOException e) {e.printStackTrace();}return returnFile;}

4、参考文献:

https://www.cnblogs.com/cmelody/p/7066232.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/139583.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

vim 中批量添加注释

批量注释&#xff1a;Ctrl v 进入块选择模式&#xff0c;然后移动光标选中你要注释的行&#xff0c;再按大写的 I 进入行首插入模式输入注释符号如 // 或 #&#xff0c;输入完毕之后&#xff0c;按两下 ESC&#xff0c;Vim 会自动将你选中的所有行首都加上注释&#xff0c;保存…

适用于初学者的 .NET MAUI

适用于初学者的 .NET MAUI | Microsoft Learn 记录微软Learn中用到的代码。文章比较粗糙&#xff0c;大部分是项目代码粘贴。想详细学习的可到上面的链接学习&#xff0c;代码可以从这里复制后直接运行。 练习中一共有两个页面&#xff1a; 1、MainPage.xaml 用于添加列表中的…

logback.xml文件例子

用于服务器里保存日志文件 1、样例一&#xff1a; <?xml version"1.0" encoding"UTF-8"?> <configuration><!--定义日志文件的存储地址 勿在 LogBack 的配置中使用相对路径--><property name"LOG_HOME" value"/opt…

No182.精选前端面试题,享受每天的挑战和学习

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6 🍨 阿珊和她的猫_CSDN个人主页 🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入…

【Unity实战】实现强大通用易扩展的对话系统(附项目源码)

文章目录 先看看实现的最终效果前言素材前期准备工作1. 简单绘制地形2. 绘制对话框3. 配置人物动画4. 实现简单的控制人物移动 控制对话框的显示隐藏定义对话内容实现简单的对话功能逐字打印效果按下按键快速显示文本实现多个NPC配置不同对话扩展TextAsset 读取文档文件实际应用…

No183.精选前端面试题,享受每天的挑战和学习

🤍 前端开发工程师(主业)、技术博主(副业)、已过CET6 🍨 阿珊和她的猫_CSDN个人主页 🕠 牛客高级专题作者、在牛客打造高质量专栏《前端面试必备》 🍚 蓝桥云课签约作者、已在蓝桥云课上架的前后端实战课程《Vue.js 和 Egg.js 开发企业级健康管理项目》、《带你从入…

Mac电脑配置Flutter开发环境

1.进入官网下载页&#xff1a; Flutter SDK releases | Flutter 可以看到有 Windows、macOS、Linux三种系统的下载包 选择macOS&#xff0c;然后点击下载 Stable channel&#xff08;稳定版&#xff09;中的最新版本&#xff0c;下载完成后可以移动到资源库Library中。 2.下载…

asp.net blazor集成TinyMCE.Blazor

asp.net blazor项目添加TinyMCE.Blazor nuget包 在blazor页面中添加&#xff0c;可以通过ScriptSrc参数配置自定义TinyMCE.Blazor js <EditForm class"mb-3" Model"Model" OnValidSubmit"HandleValidSubmit"><div class"form-gro…

TCP触发海康扫码相机S52CN-IC-JQR-NNN25

PC环境设置 为保证客户端正常运行以及数据传输的稳定性&#xff0c;在使用客户端软件前&#xff0c;需要对 PC 环境 进行设置 关闭防火墙 操作步骤如下&#xff1a; 1. 打开系统防火墙。 2. 在自定义设置界面中&#xff0c;选择关闭防火墙的对应选项&#xff0c;并单击…

关于保留VLAN

1.定义 保留VLAN是作为交换机系统内部控制面通道以及部分特性的用户业务数据的承载通道。 是不是感觉有点晦涩难懂捏&#xff1f; 2.保留VLAN的ID范围 总范围&#xff1a;4064-4094 镜像口功能占用VLAN&#xff1a;4064-4071 后续拓展保留&#xff1a;4072-4094 系统占用…

74hc595模块参考

74hc595模块参考 8位串行并行输出&#xff08;SIPO&#xff09;移位寄存器 使用74HC595移位寄存器扩展微控制器上的输出引脚数量。如果你需要扩充输入引脚的数量那么你需要74HC165移位寄存器。 SER&#xff08;串行输入&#xff09;引脚用于一次一位地将数据发送到移位寄存器…

快速教程|如何在 AWS EC2上使用 Walrus 部署 GitLab

Walrus 是一款基于平台工程理念的开源应用管理平台&#xff0c;致力于解决应用交付领域的深切痛点。借助 Walrus 将云原生的能力和最佳实践扩展到非容器化环境&#xff0c;并支持任意应用形态统一编排部署&#xff0c;降低使用基础设施的复杂度&#xff0c;为研发和运维团队提供…

MyBatis总结

简介 MyBatis是一款持久层框架&#xff0c;是基于JDBC的开发。 基本使用 mybatis配置文件设计标签和顶层结构如下&#xff1a; configuration&#xff08;配置&#xff09; properties&#xff08;属性&#xff09; settings&#xff08;设置&#xff09; typeAliases&…

ChatGPT辅助下的小组学习

1 网上分享会-主题 1.9曾子曰&#xff1a;“慎终追远&#xff0c;民德归厚矣。” Master Zeng said:“Be circumspect in funerary services and continue sacrifices to the distant ancestors, and the virtue (de 德) of the common people will thrive.” 2 过程记录 听…

Solr搜索参数详解

Solr 页面搜索 1.1 基本查询 参数意义q查询的关键字&#xff0c;此参数最为重要&#xff0c;例如&#xff0c;qid:1&#xff0c;默认为q:&#xff0c;fl指定返回哪些字段&#xff0c;用逗号或空格分隔&#xff0c;注意&#xff1a;字段区分大小写&#xff0c;例如&#xff0c;…

459. 重复的子字符串

459. 重复的子字符串 原题链接&#xff1a;完成情况&#xff1a;解题思路&#xff1a;参考代码&#xff1a;__459重复的子字符串_枚举__459重复的子字符串_字符串匹配__459重复的子字符串_KMP算法__459重复的子字符串_优化的KMP算法 错误经验吸取 原题链接&#xff1a; 459. …

酷开科技持续推动智能投影行业创新发展

近年来&#xff0c;投影仪逐渐成为年轻人追捧的家居时尚单品。据国际数据公司&#xff08;IDC&#xff09;报告显示&#xff0c;2022年中国投影机市场总出货量505万台&#xff0c;超80%为家用投影仪。相比于电视&#xff0c;投影仪外观小巧、屏幕大小可调节&#xff0c;无论是卧…

OpenCV:图像旋转与缩放

人工智能的学习之路非常漫长&#xff0c;不少人因为学习路线不对或者学习内容不够专业而举步难行。不过别担心&#xff0c;我为大家整理了一份600多G的学习资源&#xff0c;基本上涵盖了人工智能学习的所有内容。点击下方链接,0元进群领取学习资源,让你的学习之路更加顺畅!记得…

从白日梦到现实:推出 Elastic 的管道查询语言 ES|QL

作者&#xff1a;George Kobar, Bahubali Shetti, Mark Settle 今天&#xff0c;我们很高兴地宣布 Elastic 的新管道查询语言 ES|QL&#xff08;Elasticsearch 查询语言&#xff09;的技术预览版&#xff0c;它可以转换、丰富和简化数据调查。 ES|QL 由新的查询引擎提供支持&am…

Git基础知识学习常用命令一

常用命令 $ git status 工作区域与仓库保持一致step2: 暂存状态 $ git add --all # 当前项目下的所有更改 $ git add . # 当前目录下的所有更改 $ git add xx/xx.py xx/xx2.py # 添加某几个文件Step3: commit $ git commit -m"<这里写commit的描述>" 已提…