springmvc实现导出数据信息为excle表格示例代码

所属分类: 软件编程 / java 阅读数: 32
收藏 0 赞 0 分享

1.项目增加导出日志信息

2.项目中导入poi-*.jar等操作excel文件的jar文件

  • poi-3.7-20120326.jar
  • poi-excelant-3.7-20101029.jar
  • poi-ooxml-3.7.jar
  • poi-ooxml-schemas-3.7.jar

Excel导出就是根据前台条件将参数传到controller,根据参数去数据库中进行查询,查询出list集合,将list集合生成excle数据下载。

代码片段:

Contorller.Java

/** 
   * 导出信息 
   * @param model 
   */ 
  @RequestMapping("exportCustomer.do") 
  @SystemControllerLog(description = "数据库表单导出Excle") 
  public void exportCustomer(ModelMap model) { 
    //TODO 如需添加条件 
    //model.addAttribute("username", nameStr); 
    //获取需要导出的数据List 
    List<CMcustomer> cusList=customerService.exportCustomer(model); 
      //使用方法生成excle模板样式 
    HSSFWorkbook workbook = customerService.createExcel(cusList, request); 
    SimpleDateFormat format = new SimpleDateFormat("yyyyMMddHHmmss"); // 定义文件名格式 
 
    try { 
    //定义excle名称 ISO-8859-1防止名称乱码 
      String msg = new String( 
          ("客户信息_" + format.format(new Date()) + ".xls").getBytes(), 
          "ISO-8859-1"); 
      // 以导出时间作为文件名 
      response.setContentType("application/vnd.ms-excel"); 
      response.addHeader("Content-Disposition", "attachment;filename=" 
          + msg); 
      workbook.write(response.getOutputStream()); 
    } catch (IOException e) { 
      logger.error(e); 
    } 
  } 

2.Service中createExcel方法

public HSSFWorkbook createExcel(List<CMcustomer> cusList, 
    HttpServletRequest request) { 
 
    // 创建一个webbook,对应一个excel文件 
    HSSFWorkbook workbook = new HSSFWorkbook(); 
    // 在webbook中添加一个sheet,对应excel文件中的sheet 
    HSSFSheet sheet = workbook.createSheet("客户信息表"); 
    // 设置列宽 
    sheet.setColumnWidth(0, 25 * 100); 
    sheet.setColumnWidth(1, 35 * 100); 
    sheet.setColumnWidth(2, 35 * 100); 
    sheet.setColumnWidth(3, 40 * 100); 
    sheet.setColumnWidth(4, 45 * 100); 
    sheet.setColumnWidth(5, 45 * 100); 
    sheet.setColumnWidth(6, 50 * 100); 
    sheet.setColumnWidth(7, 80 * 100); 
    sheet.setColumnWidth(8, 35 * 100); 
    sheet.setColumnWidth(9, 40 * 100); 
    // 在sheet中添加表头第0行 
    HSSFRow row = sheet.createRow(0); 
    // 创建单元格,并设置表头,设置表头居中 
    HSSFCellStyle style = workbook.createCellStyle(); 
    // 创建一个居中格式 
    style.setAlignment(HSSFCellStyle.ALIGN_CENTER); 
    // 带边框 
    style.setBorderBottom(HSSFCellStyle.BORDER_THIN); 
    // 生成一个字体 
    HSSFFont font = workbook.createFont(); 
    // 字体增粗 
    font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); 
    // 字体大小 
    font.setFontHeightInPoints((short) 12); 
    // 把字体应用到当前的样式 
    style.setFont(font); 
 
    // 单独设置整列居中或居左 
    HSSFCellStyle style1 = workbook.createCellStyle(); 
    style1.setAlignment(HSSFCellStyle.ALIGN_CENTER); 
    HSSFCellStyle style2 = workbook.createCellStyle(); 
    style2.setAlignment(HSSFCellStyle.ALIGN_LEFT); 
 
    HSSFCellStyle style3 = workbook.createCellStyle(); 
    style3.setAlignment(HSSFCellStyle.ALIGN_LEFT); 
    HSSFFont hssfFont = workbook.createFont(); 
    hssfFont.setColor(HSSFFont.COLOR_RED); 
    hssfFont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); 
    style3.setFont(hssfFont); 
 
    HSSFCellStyle style4 = workbook.createCellStyle(); 
    style4.setAlignment(HSSFCellStyle.ALIGN_LEFT); 
    HSSFFont hssfFont1 = workbook.createFont(); 
    hssfFont1.setColor(HSSFFont.COLOR_NORMAL); 
    hssfFont1.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD); 
    style4.setFont(hssfFont1); 
 
    HSSFCell cell = row.createCell(0); 
    cell.setCellValue("序号"); 
    cell.setCellStyle(style); 
 
    cell = row.createCell(1); 
    cell.setCellValue("客户姓名"); 
    cell.setCellStyle(style); 
 
    cell = row.createCell(2); 
    cell.setCellValue("性别"); 
    cell.setCellStyle(style); 
 
    cell = row.createCell(3); 
    cell.setCellValue("状态"); 
    cell.setCellStyle(style); 
 
    cell = row.createCell(4); 
    cell.setCellValue("电话"); 
    cell.setCellStyle(style); 
 
    cell = row.createCell(5); 
    cell.setCellValue("邮箱"); 
    cell.setCellStyle(style); 
 
    cell = row.createCell(6); 
    cell.setCellValue("地址"); 
    cell.setCellStyle(style); 
    for (int i = 0; i < cusList.size(); i++) { 
      String logTypeDis = ""; 
      row = sheet.createRow(i + 1); 
      CMcustomer cMcustomer = cusList.get(i); 
      // 创建单元格,并设置值 
      // 编号列居左 
      HSSFCell c1 = row.createCell(0); 
      c1.setCellStyle(style2); 
      c1.setCellValue(i); 
      HSSFCell c2 = row.createCell(1); 
      c2.setCellStyle(style1); 
      c2.setCellValue(cMcustomer.getCustomername());//客户姓名 
 
      String sexStr = cMcustomer.getSex();//性别 0:女,1:男 
      String sex=""; 
      if ("1".equals(sexStr)) { 
        sex="男"; 
      } 
      if ("0".equals(sexStr)) { 
        sex="女"; 
      } 
      HSSFCell c3 = row.createCell(2);//性别 
      c3.setCellStyle(style1); 
      c3.setCellValue(sex); 
       
      String statusStr = cMcustomer.getStatus();//客户状态1.在职,2.离职 
      String status=""; 
      if ("1".equals(statusStr)) { 
        status="在职"; 
      } 
      if ("2".equals(statusStr)) { 
        status="离职"; 
      } 
      HSSFCell c4 = row.createCell(3);//状态 
      c4.setCellStyle(style1); 
      c4.setCellValue(status); 
      String customerid = cMcustomer.getCustomerid();//客户id 
      List<CMphone> phoneList = cMphoneMapper.selectByCustomerid(customerid); 
      String phone=""; 
      if (phoneList!=null&&phoneList.size()>0) { 
        for (int j = 0; j < phoneList.size(); j++) { 
          phone = phoneList.get(j).getPhone(); 
        } 
      } 
      HSSFCell c5 = row.createCell(4);//电话 
      c5.setCellStyle(style1); 
      c5.setCellValue(phone); 
      List<CMemail> emailList = cMemailMapper.selectAll(customerid); 
      String email=""; 
      if (emailList!=null&&emailList.size()>0) { 
        for (int j = 0; j < emailList.size(); j++) { 
          email = emailList.get(j).getEmail(); 
        } 
      } 
      HSSFCell c6 = row.createCell(5);//邮箱 
      c6.setCellStyle(style1); 
      c6.setCellValue(email); 
      CMaddress cMaddress=new CMaddress(); 
      cMaddress.setCustomerid(customerid); 
    List<CMaddress> adderssList = cMaddressMapper.selectAll(cMaddress); 
      String adderss=""; 
      if (adderssList!=null&&adderssList.size()>0) { 
        for (int j = 0; j < adderssList.size(); j++) { 
          adderss = adderssList.get(j).getAddress(); 
        } 
      } 
      HSSFCell c7 = row.createCell(6);//地址 
      c7.setCellStyle(style1); 
      c7.setCellValue(adderss); 
 
      //使用默认格式 
      row.createCell(1).setCellValue(cMcustomer.getCustomername()); 
      row.createCell(2).setCellValue(sex); 
      row.createCell(3).setCellValue(status); 
      row.createCell(4).setCellValue(phone); 
      row.createCell(5).setCellValue(email); 
      row.createCell(6).setCellValue(adderss); 
    } 
    return workbook; 
} 

3.页面jsp调用

//导出信息 
    function exporBtn(){ 
    $.ajax({ 
      type:"POST", 
      url:"<%=path%>/customer/exportCustomer.do", 
      success:function(data){ 
        window.open('<%=path%>/customer/exportCustomer.do'); 
      } 
       
    }); 
  } 

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

更多精彩内容其他人还在看

Java的面向对象编程基本概念学习笔记整理

这篇文章主要介绍了Java的面向对象编程基本概念学习笔记整理,包括类与方法以及多态等支持面向对象语言中的重要特点,需要的朋友可以参考下
收藏 0 赞 0 分享

Eclipse下编写java程序突然不会自动生成R.java文件和包的解决办法

这篇文章主要介绍了Eclipse下编写java程序突然不会自动生成R.java文件和包的解决办法 的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

基于Java实现杨辉三角 LeetCode Pascal's Triangle

这篇文章主要介绍了基于Java实现杨辉三角 LeetCode Pascal's Triangle的相关资料,需要的朋友可以参考下
收藏 0 赞 0 分享

Java中Spring获取bean方法小结

Spring是一个轻量级的控制反转(IoC)和面向切面(AOP)的容器框架,如何在程序中获取Spring配置的bean呢?下面通过本文给大家介绍Java中Spring获取bean方法小结,对spring获取bean方法相关知识感兴趣的朋友一起学习吧
收藏 0 赞 0 分享

如何计算Java对象占用了多少空间?

在Java中没有sizeof运算符,所以没办法知道一个对象到底占用了多大的空间,但是在分配对象的时候会有一些基本的规则,我们根据这些规则大致能判断出来对象大小,需要的朋友可以参考下
收藏 0 赞 0 分享

剖析Java中的事件处理与异常处理机制

这篇文章主要介绍了Java中的事件处理与异常处理机制,讲解Java是如何对事件或者异常作出响应以及定义异常的一些方法,需要的朋友可以参考下
收藏 0 赞 0 分享

详解Java的Struts2框架的结构及其数据转移方式

这篇文章主要介绍了详解Java的Struts2框架的结构及其数据转移方式,Struts框架是Java的SSH三大web开发框架之一,需要的朋友可以参考下
收藏 0 赞 0 分享

Java封装好的mail包发送电子邮件的类

本文给大家分享了2个java封装好的mail包发送电子邮件的类,并附上使用方法,小伙伴们可以根据自己的需求自由选择。
收藏 0 赞 0 分享

在Java的Struts中判断是否调用AJAX及用拦截器对其优化

这篇文章主要介绍了在Java的Struts中判断是否调用AJAX及用拦截器对其优化的方法,Struts框架是Java的SSH三大web开发框架之一,需要的朋友可以参考下
收藏 0 赞 0 分享

java多线程Future和Callable类示例分享

JAVA多线程实现方式主要有三种:继承Thread类、实现Runnable接口、使用ExecutorService、Callable、Future实现有返回结果的多线程。其中前两种方式线程执行完后都没有返回值,只有最后一种是带返回值的。今天我们就来研究下Future和Callab
收藏 0 赞 0 分享
查看更多