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

相关推荐
极客先躯33 分钟前
高级java每日一道面试题-2024年10月3日-分布式篇-分布式系统中的容错策略都有哪些?
java·分布式·版本控制·共识算法·超时重试·心跳检测·容错策略
夜月行者1 小时前
如何使用ssm实现基于SSM的宠物服务平台的设计与实现+vue
java·后端·ssm
程序猿小D1 小时前
第二百六十七节 JPA教程 - JPA查询AND条件示例
java·开发语言·前端·数据库·windows·python·jpa
bin91531 小时前
【EXCEL数据处理】000017 案例 Match和Index函数。
excel
潘多编程1 小时前
Java中的状态机实现:使用Spring State Machine管理复杂状态流转
java·开发语言·spring
_阿伟_2 小时前
SpringMVC
java·spring
代码在改了2 小时前
springboot厨房达人美食分享平台(源码+文档+调试+答疑)
java·spring boot
猿java2 小时前
使用 Kafka面临的挑战
java·后端·kafka
wclass-zhengge2 小时前
数据结构篇(绪论)
java·数据结构·算法
何事驚慌2 小时前
2024/10/5 数据结构打卡
java·数据结构·算法