Controller 层

  1. /**
  2. * 考勤机刷卡明细导出Excel
  3. *
  4. * @throws Exception
  5. */
  6. // @RequiresPermissions("report:ExportToExcel")
  7. @RequestMapping(value = "/AttendMachineCardDetailsExportToExcel", method = RequestMethod.POST)
  8. public void attendMachineCardDetailsExportToExcel(@RequestParam(value = "workTimeDateStart", required = false) String workTimeDateStart,
  9. @RequestParam(value = "workTimeDateEnd", required = false) String workTimeDateEnd,
  10. @RequestParam(value = "userName", required = false) String userName,
  11. @RequestParam(value = "userType", required = false) String userType,
  12. HttpServletRequest request,
  13. HttpServletResponse response) throws Exception {
  14. AttendMachineCard attendMachineCard = new AttendMachineCard();
  15. attendMachineCard.setWorkTimeDateStart(workTimeDateStart);
  16. attendMachineCard.setWorkTimeDateEnd(workTimeDateEnd);
  17. attendMachineCard.setUserName(userName);
  18. attendMachineCard.setUserType(userType);
  19. List<AttendMachineCard> list = attendMachineCardServiceImpl.getAttendMachineCardList(attendMachineCard);//用于查询,返回结果
  20. attendMachineCardServiceImpl.exportAttendMachineCardDetails(list, request, response);//导出Excle
  21. }

ServiceImpl

  1. @Service
  2. public class AttendMachineCardServiceImpl implements AttendMachineCardService{
  3. @Autowired
  4. private AttendMachineCardMapper attendMachineCardMapper;
  5. @Autowired
  6. private SysLogMapper sysLogMapper;
  7. @Override
  8. public List<AttendMachineCard> getAttendMachineCardList(AttendMachineCard attendMachineCard) {
  9. List<AttendMachineCard> attendMachineCardList = null;
  10. try {
  11. attendMachineCardList = attendMachineCardMapper.getAttendMachineCardList(attendMachineCard);
  12. } catch (Exception e) {
  13. throw new OutsideSystemServiceException(ResultEnum.SEARCH_ATTEND_MACHINE_CARD_ERROR,e);
  14. }
  15. return attendMachineCardList;
  16. }
  17. @Override
  18. public void exportAttendMachineCardDetails(List<AttendMachineCard> attendMachineCard, HttpServletRequest request, HttpServletResponse response) throws IOException {
  19. // set content attributes for the response
  20. try {
  21. this.logexportLogDetails(request);
  22. } catch (Exception e) {
  23. e.printStackTrace();
  24. }
  25. response.setContentType("application/octet-stream");
  26. response.setHeader("Content-Disposition", "attachment; filename=人员考勤信息统计表.xlsx");
  27. // 创建工作薄
  28. try (XSSFWorkbook workbook = new XSSFWorkbook();) {
  29. // 创建工作表
  30. XSSFSheet sheet = workbook.createSheet("人员考勤信息统计表");
  31. createExcelContentDetails(attendMachineCard, sheet);
  32. workbook.write(response.getOutputStream());
  33. }
  34. response.flushBuffer();
  35. }
  36. private void createExcelContentDetails(List<AttendMachineCard> attendMachineCards,XSSFSheet sheet){
  37. XSSFRow titleRow = sheet.createRow(0);
  38. for (int col = 0; col < 7; col++) {
  39. // 向工作表中添加数据
  40. titleRow.createCell(col);
  41. }
  42. titleRow.getCell(0).setCellValue("姓名");
  43. titleRow.getCell(1).setCellValue("人员类别");
  44. titleRow.getCell(2).setCellValue("刷卡日期");
  45. titleRow.getCell(3).setCellValue("刷卡时间");
  46. titleRow.getCell(4).setCellValue("签到类型");
  47. titleRow.getCell(5).setCellValue("签到方式");
  48. titleRow.getCell(6).setCellValue("设备编号");
  49. sheet.setColumnWidth(0, 30 * 256);
  50. sheet.setColumnWidth(1, 30 * 256);
  51. sheet.setColumnWidth(2, 30 * 256);
  52. sheet.setColumnWidth(3, 30 * 256);
  53. sheet.setColumnWidth(4, 30 * 256);
  54. sheet.setColumnWidth(5, 30 * 256);
  55. sheet.setColumnWidth(6, 30 * 256);
  56. // 数据行
  57. for (int row = 1; row < attendMachineCards.size() + 1; row++) {
  58. XSSFRow rows = sheet.createRow(row);
  59. for (int col = 0; col < 7; col++) {
  60. rows.createCell(col);
  61. }
  62. AttendMachineCard attendMachineCard = attendMachineCards.get(row - 1);
  63. rows.getCell(0).setCellValue(attendMachineCard.getUserName());
  64. rows.getCell(1).setCellValue(attendMachineCard.getUserType());
  65. rows.getCell(2).setCellValue(attendMachineCard.getPunckDate());
  66. rows.getCell(3).setCellValue(attendMachineCard.getPunckTime());
  67. rows.getCell(4).setCellValue(attendMachineCard.getSignType());
  68. rows.getCell(5).setCellValue(attendMachineCard.getWayOfSigningIn());
  69. rows.getCell(6).setCellValue(attendMachineCard.getNumber());
  70. }
  71. }
  72. }

Java导出Excel(项目实战Demo)的更多相关文章

  1. Java导出Excel和CSV(简单Demo)

    Java导出Excel和CSV的简单实现,分别使用POI和JavaCSV. JavaBean public class ReportInfo { int id; String date; int nu ...

  2. [转载]Java导出Excel

    一.需求介绍 当前B/S模式已成为应用开发的主流,而在开发企业办公系统的过程中,常常有客户这样子要求:把系统数据库中的数据导出到Excel,用户查看报表时直接用Excel打开.或者是:用户已经习惯用E ...

  3. java导出excel报错:getOutputStream() has already been called for this response

    对于java导出excel报错的问题,查了很多都说是在使用完输出流以后调用以下两行代码即可 out.clear(); out = pageContext.pushBody(); 但这也许是页面上输出时 ...

  4. java导出excel表格

    java导出excel表格: 1.导入jar包 <dependency> <groupId>org.apache.poi</groupId> <artifac ...

  5. java导出excel报表

    1.java导出excel报表: package cn.jcenterhome.util; import java.io.OutputStream;import java.util.List;impo ...

  6. java设计模式综合项目实战视频教程

    java设计模式综合项目实战视频教程 视频课程目录如下: 第01节课:本课程整体内容介绍:X-gen系统概况,包括:引入.X-gen项目背景.X-gen的HelloWorld第02节课:X-gen整体 ...

  7. Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类

    Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类 ============================== ©Copyright 蕃薯耀 20 ...

  8. java导出excel模板数据

    Java导出excel数据模板,这里直接贴代码开发,流程性的走下去就是步骤: String[] colName=new String[]{"期间","科目代码" ...

  9. java导出excel工具类

    java导出excel须要使用HSSFWorkbook这个类,须要导入poi-3.6-20091214.jar 工具类调用例如以下: package com.qlwb.business.util; i ...

随机推荐

  1. Centos5.5更新源

    将之前的CentOS-Base.repo文件里的内容换成如下内容 vi /etc/yum.repos.d/CentOS-Base.repo # CentOS-Base.repo## The mirro ...

  2. Kubernetes的控制器之Deployment的定义

    Deploy 的控制器定义参数介绍 [root@master manifests]# kubectl explain deploy KIND: Deployment VERSION: extensio ...

  3. 浅谈SPFA——洛谷P1576 最小花费 题解

    想找原题请点击这里:传送门 原题: 题目描述 在n个人中,某些人的银行账号之间可以互相转账.这些人之间转账的手续费各不相同.给定这些人之间转账时需要从转账金额里扣除百分之几的手续费,请问A最少需要多少 ...

  4. Nginx 七层反向代理

    目录 1.代理 2.正向代理 3.反向代理 4.Nginx 反向代理 5.Nginx 反向代理相关指令介绍 ①.listen ②.server_name ③.location ④.proxy_pass ...

  5. SpringMVC中在Controller类的每个方法执行前调用某个方法的实现

    在使用SpringMVC做项目的时候,如果想在@Controller类中每个@RequestMapping方法执行前都调用某个方法,要怎么实现呢?答案是使用Spring的@ModelAttribute ...

  6. python第一章 python基础编程

    第一次学习python 首先python对于我来说是我学习的第三门语言,之前大一学习过了c和c++这两门语言. 接触一个新语言,首先应该的是搭载一下编译的环境.我们是老师给我们上传了的python3安 ...

  7. 《JavaScript高级程序设计》读书笔记(序)

    1.现大三暑假中,计划9月初北上找前端工作,大三一年时间都在健身和学习专业课知识,技术有点荒废了,7月份忙于学校安排的实习javaweb方向的,到现在才有整段的时间好好把基础巩固一. 2.这几天也在关 ...

  8. SpringBoot yml文件语法

    SpringBoot提供了大量的默认配置,如果要修改默认配置,需要在配置文件中修改. SpringBoot默认会加载resource下的配置文件: application*.yml applicati ...

  9. 奖学金(0)<P2007_1>

    奖学金 (scholar.pas/c/cpp) [问题描述] 某小学最近得到了一笔赞助,打算拿出其中一部分为学习成绩优秀的前5名学生发奖学金.期末,每个学生都有3门课的成绩:语文.数学.英语.先按总分 ...

  10. Mayor's posters-POJ2528 区间染色+离散化

    题意: 在一面长度为10000000 的墙上贴广告,告诉你每张海报的l,r(1 <= li <= ri <= 10000000.),让你求最后有几张海报露出来 链接:http://p ...