对代码有两点 说明:

第一点:

js发出请求的时候,多人测试不能用ajax发送,是个坑,正确的方式如下,至于原因,自己研究,我也不清楚,下面文章中有带参数的方式

var url = getRootPath() + "/event/exportExcel.do";   
location.href = url;

//window.open(url);

一般上面两种格式才能正确发送

第二点:

导出excel,点击导出按钮后具体是直接保存,还有弹窗选择路径,或是修改文件名,是由浏览器决定的,不是由代码程序决定的!!

基本上操作正确,可以复制粘贴使用,因为我也是粘贴别人,并且差不多只修改了传进来的数据

先准备pom:

<dependency><groupId>org.apache.poi</groupId><artifactId>poi-ooxml</artifactId><version>3.9</version>
</dependency>

第一步,放一个工具类

package com.xxx.system.util;
import java.io.IOException;
import java.io.OutputStream;
import java.net.URLEncoder;
import java.util.ArrayList;
import java.util.List;  import javax.servlet.http.HttpServletResponse;  import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFRichTextString;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.HSSFColor;
import org.apache.poi.ss.util.CellRangeAddress;  public class ExportExcelUtils {  private String title; // 导出表格的表名  private String[] rowName;// 导出表格的列名  private List<Object[]>  dataList = new ArrayList<Object[]>(); // 对象数组的List集合  private HttpServletResponse  response;  // 传入要导入的数据  public ExportExcelUtils(String title, String[] rowName,List<Object[]>  dataList,HttpServletResponse  response){  this.title=title;  this.rowName=rowName;  this.dataList=dataList;  this.response = response;  }  // 导出数据  public void exportData(){  try {  HSSFWorkbook workbook =new HSSFWorkbook(); // 创建一个excel对象  HSSFSheet sheet =workbook.createSheet(title); // 创建表格  // 产生表格标题行  HSSFRow rowm  =sheet.createRow(0);  // 行  HSSFCell cellTiltle =rowm.createCell(0);  // 单元格  // sheet样式定义  HSSFCellStyle columnTopStyle = this.getColumnTopStyle(workbook); // 头样式  HSSFCellStyle style = this.getStyle(workbook);  // 单元格样式  /**  * 参数说明  * 从0开始   第一行 第一列 都是从角标0开始  * 行 列 行列    (0,0,0,5)  合并第一行 第一列  到第一行 第六列  * 起始行,起始列,结束行,结束列  *   * new Region()  这个方法使过时的  */  // 合并第一行的所有列  sheet.addMergedRegion(new CellRangeAddress(0, (short) 0, 0, (short) (rowName.length-1)));  cellTiltle.setCellStyle(columnTopStyle);  cellTiltle.setCellValue(title);   int columnNum = rowName.length;  // 表格列的长度  HSSFRow rowRowName = sheet.createRow(1);  // 在第二行创建行  HSSFCellStyle cells =workbook.createCellStyle();  cells.setBottomBorderColor(HSSFColor.BLACK.index);    rowRowName.setRowStyle(cells);  // 循环 将列名放进去  for (int i = 0; i < columnNum; i++) {  HSSFCell  cellRowName = rowRowName.createCell((int)i);  cellRowName.setCellType(HSSFCell.CELL_TYPE_STRING); // 单元格类型  HSSFRichTextString text = new HSSFRichTextString(rowName[i]);  // 得到列的值  cellRowName.setCellValue(text); // 设置列的值  cellRowName.setCellStyle(columnTopStyle); // 样式  }  // 将查询到的数据设置到对应的单元格中  for (int i = 0; i < dataList.size(); i++) {  Object[] obj = dataList.get(i);//遍历每个对象  HSSFRow row = sheet.createRow(i+2);//创建所需的行数  for (int j = 0; j < obj.length; j++) {  HSSFCell  cell = null;   //设置单元格的数据类型   if(j==0){  // 第一列设置为序号  cell = row.createCell(j,HSSFCell.CELL_TYPE_NUMERIC);  cell.setCellValue(i+1);  }else{  cell = row.createCell(j,HSSFCell.CELL_TYPE_STRING);  if(!"".equals(obj[j]) && obj[j] != null){    cell.setCellValue(obj[j].toString());                       //设置单元格的值    }else{  cell.setCellValue("  ");  }    }  cell.setCellStyle(style); // 样式  }  }  //  让列宽随着导出的列长自动适应  for (int i = 0; i < 15; i++ ) {//15表示有十五列sheet.autoSizeColumn((short)i);// 设置自动宽度,但是控制不了表头,只能做下面if的判断if (sheet.getColumnWidth(i) < 4000) {sheet.setColumnWidth(i, 4000);}}if(workbook !=null){    try    {    // excel 表文件名  String fileName = title + String.valueOf(System.currentTimeMillis()).substring(4, 13) + ".xls";    String fileName11 = URLEncoder.encode(fileName,"UTF-8");  String headStr = "attachment; filename=\"" + fileName11 + "\"";    response.setContentType("APPLICATION/OCTET-STREAM");    response.setHeader("Content-Disposition", headStr);    OutputStream out = response.getOutputStream();    workbook.write(out);  out.flush();  out.close();  }    catch (IOException e)    {    e.printStackTrace();    }   }    }catch(Exception e){    e.printStackTrace();    }    }    public HSSFCellStyle getColumnTopStyle(HSSFWorkbook workbook) {    // 设置字体    HSSFFont font = workbook.createFont();    //设置字体大小    font.setFontHeightInPoints((short)11);    //字体加粗    font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);    //设置字体名字     font.setFontName("Courier New");    //设置样式;     HSSFCellStyle style = workbook.createCellStyle();    //设置底边框;     style.setBorderBottom(HSSFCellStyle.BORDER_THIN);    //设置底边框颜色;      style.setBottomBorderColor(HSSFColor.BLACK.index);    //设置左边框;       style.setBorderLeft(HSSFCellStyle.BORDER_THIN);    //设置左边框颜色;     style.setLeftBorderColor(HSSFColor.BLACK.index);    //设置右边框;     style.setBorderRight(HSSFCellStyle.BORDER_THIN);    //设置右边框颜色;     style.setRightBorderColor(HSSFColor.BLACK.index);    //设置顶边框;     style.setBorderTop(HSSFCellStyle.BORDER_THIN);    //设置顶边框颜色;      style.setTopBorderColor(HSSFColor.BLACK.index);    //在样式用应用设置的字体;      style.setFont(font);    //设置自动换行;     style.setWrapText(false);    //设置水平对齐的样式为居中对齐;      style.setAlignment(HSSFCellStyle.ALIGN_CENTER);    //设置垂直对齐的样式为居中对齐;     style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);    return style;    }    public HSSFCellStyle getStyle(HSSFWorkbook workbook) {    // 设置字体    HSSFFont font = workbook.createFont();    //设置字体大小    //font.setFontHeightInPoints((short)10);    //字体加粗    //font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);    //设置字体名字     font.setFontName("Courier New");    //设置样式;     HSSFCellStyle style = workbook.createCellStyle();    //设置底边框;     style.setBorderBottom(HSSFCellStyle.BORDER_THIN);    //设置底边框颜色;      style.setBottomBorderColor(HSSFColor.BLACK.index);    //设置左边框;       style.setBorderLeft(HSSFCellStyle.BORDER_THIN);    //设置左边框颜色;     style.setLeftBorderColor(HSSFColor.BLACK.index);    //设置右边框;     style.setBorderRight(HSSFCellStyle.BORDER_THIN);    //设置右边框颜色;     style.setRightBorderColor(HSSFColor.BLACK.index);    //设置顶边框;     style.setBorderTop(HSSFCellStyle.BORDER_THIN);    //设置顶边框颜色;      style.setTopBorderColor(HSSFColor.BLACK.index);    //在样式用应用设置的字体;      style.setFont(font);    //设置自动换行;     style.setWrapText(false);    //设置水平对齐的样式为居中对齐;      style.setAlignment(HSSFCellStyle.ALIGN_CENTER);    //设置垂直对齐的样式为居中对齐;     style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);    return style;    }
} 

第二步,前台js发出请求

 //  GET加json等不正常参数要进行编码encodeURIComponent(),因为需要才加的参数,一般不需要加var url = getRootPath() + "/event/exportExcel.do?params="+encodeURIComponent(jsonParams);  location.href = url; //window.open(url);

第三步,控制器处理(最后一行代码调用工具类)

@RequestMapping("exportExcel")@ResponseBodypublic ModelAndView exportExcel(HttpServletRequest request,HttpServletResponse response){  try {      String params = request.getParameter("params");//这两行取出从js传回来的参数,没参数的可以不用JSONObject json = JSONObject.fromObject(params);List<Map<String, Object>> list = eventService.getData(json);//这行是数据库取到的数据,根据自己的需求变动String title ="代办事件";  String[] rowsName=new String[]{"序号","第二列标题","第三列标题","第四列标题"};  List<Object[]>  dataList = new ArrayList<Object[]>();  Object[] objs = null;  for (int i = 0; i < list.size(); i++) {  Map<String, Object> event =list.get(i);  objs = new Object[rowsName.length];  objs[0] = i;  objs[1] = event.get("对应参数1");  objs[2] = event.get("对应参数2");  objs[3] = event.get("对应参数3");  dataList.add(objs);  }  ExportExcelUtils ex =new ExportExcelUtils(title, rowsName, dataList,response);  ex.exportData();  } catch (Exception e) {  e.printStackTrace();  }  return null;  } 对应参数1");  objs[2] = event.get("对应参数2");  objs[3] = event.get("对应参数3");  dataList.add(objs);  }  ExportExcelUtils ex =new ExportExcelUtils(title, rowsName, dataList,response);  ex.exportData();  } catch (Exception e) {  e.printStackTrace();  }  return null;  } 

第四步,点击桌面的按钮或者链接,触发js事件,基本上就可以了。

实现主要参考文章:http://blog.csdn.NET/wangchangpen62/article/details/44410967

【导出EXCEL表格】SpringMVC中使用POI导出EXCEL表格2017年,可以直接复制粘贴使用相关推荐

  1. springboot中使用poi导出excel文件(亲测实现了第一个功能)

    1.POI简介 Jakarta POI 是一套用于访问微软格式文档的Java API. 组件HWPF用于操作Word的; 组件HSSF用于操作Excel格式文件. 2.常用组件 HSSFWorkboo ...

  2. java poi打印excel_java中对poi导出的Excel进行打印设置

    java中对poi导出的Excel进行打印设置 java中对poi导出的Excel进行打印设置 无模板时 PrintSetup ps = sheet.getPrintSetup(); // 印刷方向. ...

  3. java 中的poi_Java中使用POI操作ExceL的读与

    1.Java中使用POI操作ExceL的读与写 ​直接给代码 1.1导入依赖 org.apache.poi poi 3.10-FINAL org.apache.poi poi-ooxml 3.10-F ...

  4. html大学课程表制作,课程表模板空白表格(小/中/大学课程表模板excel) 中文免费版...

    课程表模板空白表格(小/中/大学课程表模板excel) 中文免费版 下载后可以根据自己的需求进行编辑,方便大家上课学习的安排,喜欢的朋友快来下载吧! 课程表介绍 课程表,是帮助学生了解课程安排的一种简 ...

  5. java excel 多列排序_java poi处理excel多sheet并实现排序

    需求:有一个数据字典全量汇总表,其中第一个sheet为目录,包括编号和表名,第二个以后为表的明细.其中sheet名就是表名但无序,sheet内字段序号无序有空行 现在要求将其中101,104,107, ...

  6. java excel 操作 poi_Java使用apache poi进行excel相关操作

    一.基本介绍 1.1.Apache POI介绍 Apache POI是一个可以进行微软的文档进行开源库,可以操作的文档类型包括word.ppt.excel.visio.outlook.... 本文主要 ...

  7. SpringBoot中使用POI导出Excel时怎样循环数据库数据赋值

    场景 SpringBoot中使用POI实现自定义Excel布局式导出: https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/894977 ...

  8. java中使用poi导出ppt(图片和表格)

    java使用POI导出PPT(超简单方法,包含图片和表格) 在做项目中遇到一个需求,将职员的信息导出成一个形式固定的ppt文档,poi有许多方法可以实现,因为我是一名Java小白,于是便想用最简单的方 ...

  9. java中使用poi导出Excel详解,kotlin音标

    到这个问题,可以设置encoding为双字节.POI可以到www.apache.org下载到. 编译好的jar主要有这样4个:poi包, poi Browser包, poi hdf包, poi hss ...

最新文章

  1. poj 2115 C Looooops(扩展欧几里德算法)
  2. 期盼的中国SB秀终于开始了
  3. 美观又实用,10 款强大的开源 Javascript 图表库
  4. Redis持久化-深入理解AOF,RDB
  5. Linux 内核修正 5 年历史的严重 bug
  6. 3.9 Spark 键值对RDD编程
  7. 拓端tecdat|使用R语言进行多项式回归、非线性回归模型曲线拟合
  8. c++ array容器 传参_C/C++常用技巧及初学者易错点汇总学习
  9. python 阿里云短信接口_python 之阿里云短信服务接入流程短信接口
  10. U盘文件夹乱码无法删除的原因及解决方案
  11. 鲍威尔法源程序码matlab,鲍威尔算法matlab程序.doc
  12. Qt 实现类似 Python turtle 海龟绘图的动画效果
  13. 好用文件整理工具,需要速来
  14. Mybatis之choose(where,otherwise)标签
  15. edg驱动 wobot通过ttyUSB0串口通信
  16. java课程综合实训报告_Java ME综合实训报告
  17. 51单片机PID算法控制无刷直流电机proteus仿真
  18. 以QRcode为例聊聊二维码的现状与未来(Java版本)
  19. 解析Activity的启动过程
  20. 计蒜客-A1530 Abiyoyo

热门文章

  1. Simpack2021 安装教程(附安装步骤)
  2. JDK 8和jre 8的区别
  3. (读书笔记)《玩着玩着就能成为PPT高手》——事前准备不能马虎
  4. 尚医通 (二十二)预约下单
  5. 2022年起重机司机(限桥式起重机)考试题模拟考试题库及模拟考试
  6. 蜘蛛纸牌(Java)课设
  7. 单片机中段程序_单片机外部中断详解及程序
  8. 为什么结构体指针需要malloc申请空间
  9. 冰点文库下载器 v3.2.9 去广告绿色版免费下载
  10. NVM(非易失存储介质)在索引结构中的机遇与挑战(未完,整理中...)