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

目录

1、POI的三个依赖

2、控制层代码

3、业务层代码

4、参考文献:


1、POI的三个依赖

XML 复制代码
<!-- 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、控制层代码

java 复制代码
@RequestMapping("/exportExcel.ctrl")
	@ResponseBody
	ResponseEntity<byte[]> exportExcel(PlcFirst record) throws UnsupportedEncodingException {
		return plcFirstService.exportExcel(record);
	}

3、业务层代码

java 复制代码
    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

相关推荐
沙漏无语1 分钟前
(一)TiDB简介
java·开发语言·tidb
Chan163 分钟前
LeetCode 热题 100 | 链表
java·数据结构·spring boot·算法·leetcode·链表·java-ee
weixin_704266053 分钟前
[特殊字符] Spring IOC/DI 核心知识点 CSDN 风格总结
java·后端·spring
袋鼠云数栈4 分钟前
构建金融级数据防线:数栈 DataAPI 的全生命周期管理实践
java·大数据·数据库·人工智能·api
indexsunny8 分钟前
互联网大厂Java面试实录:Spring Boot与微服务在电商场景中的应用解析
java·spring boot·面试·kafka·spring security·电商·microservices
独自破碎E11 分钟前
手撕真题-计算二叉树中两个节点之间的距离
java·开发语言
顺风尿一寸12 分钟前
从 Java File.length() 到 Linux 内核:一次系统调用追踪之旅
java·linux
为美好的生活献上中指15 分钟前
*Java 沉淀重走长征路*之——《Java Web 应用开发完全指南:从零到企业实战(两万字深度解析)》
java·开发语言·前端·html·javaweb·js
li星野17 分钟前
QT面试题
java·数据库·qt
不光头强17 分钟前
抽象类和接口的区别
java·开发语言·python