一、首先是导入poi所需要的jar包,我是用的是maven,添加jar包依赖

  1. <dependency>
  2. <groupId>org.apache.poi</groupId>
  3. <artifactId>poi</artifactId>
  4. <version>3.11</version>
  5. </dependency>
  6. <dependency>
  7. <groupId>org.apache.poi</groupId>
  8. <artifactId>poi-ooxml</artifactId>
  9. <version>3.11</version>
  10. </dependency>

二、导出excel工具类代码编写

  1. package com.cccuu.project.myUtils;
  2.  
  3. import org.apache.poi.hssf.usermodel.*;
  4. import org.apache.poi.hssf.util.HSSFColor;
  5. import org.apache.poi.ss.util.CellRangeAddress;
  6.  
  7. import javax.servlet.http.HttpServletResponse;
  8. import java.io.IOException;
  9. import java.io.OutputStream;
  10. import java.util.List;
  11.  
  12. /*******************************************
  13. *
  14. * @Package com.cccuu.project.myUtils
  15. * @Author duan
  16. * @Date 2018/3/29 9:12
  17. * @Version V1.0
  18. *******************************************/
  19. public class ExcelUtil {
  20.  
  21. /**
  22. * 导出excel
  23. * @param title 导出表的标题
  24. * @param rowsName 导出表的列名
  25. * @param dataList 需要导出的数据
  26. * @param fileName 生成excel文件的文件名
  27. * @param response
  28. */
  29. public void exportExcel(String title,String[] rowsName,List<Object[]> dataList,String fileName,HttpServletResponse response) throws Exception{
  30. OutputStream output = response.getOutputStream();
  31. response.reset();
  32. response.setHeader("Content-disposition",
  33. "attachment; filename="+fileName);
  34. response.setContentType("application/msexcel");
  35. this.export(title,rowsName,dataList,fileName,output);
  36. this.close(output);
  37.  
  38. }
  39.  
  40. /*
  41. * 导出数据
  42. */
  43. private void export(String title,String[] rowName,List<Object[]> dataList,String fileName,OutputStream out) throws Exception {
  44. try {
  45. HSSFWorkbook workbook = new HSSFWorkbook(); // 创建工作簿对象
  46. HSSFSheet sheet = workbook.createSheet(title); // 创建工作表
  47. HSSFRow rowm = sheet.createRow(0); // 产生表格标题行
  48. HSSFCell cellTiltle = rowm.createCell(0); //创建表格标题列
  49. // sheet样式定义; getColumnTopStyle(); getStyle()均为自定义方法 --在下面,可扩展
  50. HSSFCellStyle columnTopStyle = this.getColumnTopStyle(workbook);// 获取列头样式对象
  51. HSSFCellStyle style = this.getStyle(workbook); // 获取单元格样式对象
  52. //合并表格标题行,合并列数为列名的长度,第一个0为起始行号,第二个1为终止行号,第三个0为起始列好,第四个参数为终止列号
  53. sheet.addMergedRegion(new CellRangeAddress(0, 1, 0, (rowName.length - 1)));
  54. cellTiltle.setCellStyle(columnTopStyle); //设置标题行样式
  55. cellTiltle.setCellValue(title); //设置标题行值
  56. int columnNum = rowName.length; // 定义所需列数
  57. HSSFRow rowRowName = sheet.createRow(2); // 在索引2的位置创建行(最顶端的行开始的第二行)
  58. // 将列头设置到sheet的单元格中
  59. for (int n = 0; n < columnNum; n++) {
  60. HSSFCell cellRowName = rowRowName.createCell(n); // 创建列头对应个数的单元格
  61. cellRowName.setCellType(HSSFCell.CELL_TYPE_STRING); // 设置列头单元格的数据类型
  62. HSSFRichTextString text = new HSSFRichTextString(rowName[n]);
  63. cellRowName.setCellValue(text); // 设置列头单元格的值
  64. cellRowName.setCellStyle(columnTopStyle); // 设置列头单元格样式
  65. }
  66.  
  67. // 将查询出的数据设置到sheet对应的单元格中
  68. for (int i = 0; i < dataList.size(); i++) {
  69. Object[] obj = dataList.get(i); // 遍历每个对象
  70. HSSFRow row = sheet.createRow(i + 3); // 创建所需的行数
  71. for (int j = 0; j < obj.length; j++) {
  72. HSSFCell cell = null; // 设置单元格的数据类型
  73. if (j == 0) {
  74. cell = row.createCell(j, HSSFCell.CELL_TYPE_NUMERIC);
  75. cell.setCellValue(i + 1);
  76. } else {
  77. cell = row.createCell(j, HSSFCell.CELL_TYPE_STRING);
  78. if (!"".equals(obj[j]) && obj[j] != null) {
  79. cell.setCellValue(obj[j].toString()); // 设置单元格的值
  80. }
  81. }
  82. cell.setCellStyle(style); // 设置单元格样式
  83. }
  84. }
  85.  
  86. // 让列宽随着导出的列长自动适应
  87. for (int colNum = 0; colNum < columnNum; colNum++) {
  88. int columnWidth = sheet.getColumnWidth(colNum) / 256;
  89. for (int rowNum = 0; rowNum < sheet.getLastRowNum(); rowNum++) {
  90. HSSFRow currentRow;
  91. // 当前行未被使用过
  92. if (sheet.getRow(rowNum) == null) {
  93. currentRow = sheet.createRow(rowNum);
  94. } else {
  95. currentRow = sheet.getRow(rowNum);
  96. }
  97. if (currentRow.getCell(colNum) != null) {
  98. HSSFCell currentCell = currentRow.getCell(colNum);
  99. if (currentCell.getCellType() == HSSFCell.CELL_TYPE_STRING) {
  100. int length = currentCell.getStringCellValue()
  101. .getBytes().length;
  102. if (columnWidth < length) {
  103. columnWidth = length;
  104. }
  105. }
  106. }
  107. }
  108. if (colNum == 0) {
  109. sheet.setColumnWidth(colNum, (columnWidth - 2) * 256);
  110. } else {
  111. sheet.setColumnWidth(colNum, (columnWidth + 4) * 256);
  112. }
  113. }
  114. workbook.write(out);
  115. } catch (Exception e) {
  116. e.printStackTrace();
  117. }
  118. }
  119.  
  120. /*
  121. * 列头单元格样式
  122. */
  123. private HSSFCellStyle getColumnTopStyle(HSSFWorkbook workbook) {
  124.  
  125. // 设置字体
  126. HSSFFont font = workbook.createFont();
  127. // 设置字体大小
  128. font.setFontHeightInPoints((short) 11);
  129. // 字体加粗
  130. font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
  131. // 设置字体名字
  132. font.setFontName("Courier New");
  133. // 设置样式;
  134. HSSFCellStyle style = workbook.createCellStyle();
  135. // 设置底边框;
  136. style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
  137. // 设置底边框颜色;
  138. style.setBottomBorderColor(HSSFColor.BLACK.index);
  139. // 设置左边框;
  140. style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
  141. // 设置左边框颜色;
  142. style.setLeftBorderColor(HSSFColor.BLACK.index);
  143. // 设置右边框;
  144. style.setBorderRight(HSSFCellStyle.BORDER_THIN);
  145. // 设置右边框颜色;
  146. style.setRightBorderColor(HSSFColor.BLACK.index);
  147. // 设置顶边框;
  148. style.setBorderTop(HSSFCellStyle.BORDER_THIN);
  149. // 设置顶边框颜色;
  150. style.setTopBorderColor(HSSFColor.BLACK.index);
  151. // 在样式用应用设置的字体;
  152. style.setFont(font);
  153. // 设置自动换行;
  154. style.setWrapText(false);
  155. // 设置水平对齐的样式为居中对齐;
  156. style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
  157. // 设置垂直对齐的样式为居中对齐;
  158. style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
  159.  
  160. return style;
  161.  
  162. }
  163.  
  164. /*
  165. * 列数据信息单元格样式
  166. */
  167. private HSSFCellStyle getStyle(HSSFWorkbook workbook) {
  168. // 设置字体
  169. HSSFFont font = workbook.createFont();
  170. // 设置字体大小
  171. // font.setFontHeightInPoints((short)10);
  172. // 字体加粗
  173. // font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
  174. // 设置字体名字
  175. font.setFontName("Courier New");
  176. // 设置样式;
  177. HSSFCellStyle style = workbook.createCellStyle();
  178. // 设置底边框;
  179. style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
  180. // 设置底边框颜色;
  181. style.setBottomBorderColor(HSSFColor.BLACK.index);
  182. // 设置左边框;
  183. style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
  184. // 设置左边框颜色;
  185. style.setLeftBorderColor(HSSFColor.BLACK.index);
  186. // 设置右边框;
  187. style.setBorderRight(HSSFCellStyle.BORDER_THIN);
  188. // 设置右边框颜色;
  189. style.setRightBorderColor(HSSFColor.BLACK.index);
  190. // 设置顶边框;
  191. style.setBorderTop(HSSFCellStyle.BORDER_THIN);
  192. // 设置顶边框颜色;
  193. style.setTopBorderColor(HSSFColor.BLACK.index);
  194. // 在样式用应用设置的字体;
  195. style.setFont(font);
  196. // 设置自动换行;
  197. style.setWrapText(false);
  198. // 设置水平对齐的样式为居中对齐;
  199. style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
  200. // 设置垂直对齐的样式为居中对齐;
  201. style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
  202. return style;
  203. }
  204.  
  205. /**
  206. * 关闭输出流
  207. * @param os
  208. */
  209. private void close(OutputStream os) {
  210. if (os != null) {
  211. try {
  212. os.close();
  213. } catch (IOException e) {
  214. e.printStackTrace();
  215. }
  216. }
  217. }
  218.  
  219. }

三、测试,框架使用的是ssm

  1. @RequestMapping("exportWordData")
  2. public void exportExcelData(HttpServletRequest request,HttpServletResponse response){
  3. // 定义表的标题
  4. String title = "员工列表一览";
  5. //定义表的列名
  6. String[] rowsName = new String[] { "序号", "姓名", "性别", "特长", "学历", "入职时间", "简历", "照片", "部门" };
  7. //定义表的内容
  8. List<Object[]> dataList = new ArrayList<Object[]>();
  9. Object[] objs = new Object[9];
  10. objs[0] = "测试";
  11. objs[1] = 11;
  12. objs[2] = "111";
  13. objs[3] = "测试";
  14. objs[4] = "测试";
  15. SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd");
  16. String date = df.format(2018-12-24);
  17. objs[5] = date;
  18. objs[6] = "测试";
  19. objs[7] = "测试";
  20. objs[8] = "测试";
  21. dataList.add(objs);
  22. // 创建ExportExcel对象
  23. ExcelUtil excelUtil = new ExcelUtil();
  24.  
  25. try{
  26. String fileName= new String("测试excel文档.xlsx".getBytes("UTF-8"),"iso-8859-1"); //生成word文件的文件名
  27. excelUtil.exportExcel(title,rowsName,dataList,fileName,response);
  28. returnInfo.setResult(true);
  29.  
  30. }catch(Exception e){
  31. e.printStackTrace();
  32. }
  33. }

使用poi导出数据到excel的更多相关文章

  1. java利用poi导出数据到excel

    背景: 上一篇写到利用jtds连接数据库获取对应的数据,本篇写怎样用poi将数据到处到excel中,此程序为Application 正文: 第三方poi jar包:poi驱动包下载 代码片段: /** ...

  2. springboot2.1.8使用poi导出数据生成excel(.xlsx)文件

    前言:在实际开发中经常需要将数据库的数据导出成excel文件,poi方式则是其中一种较为常用的导出框架.简单读取excel文件在之前的一篇有说明 本项目实现需求:user发出一个导出student信息 ...

  3. spring boot 使用POI导出数据到Excel表格

    在spring boot 的项目经常碰到将数据导出到Excel表格的需求,而POI技术则对于java操作Excel表格提供了API,POI中对于多种类型的文档都提供了操作的接口,但是其对于Excel表 ...

  4. Java导出数据为EXCEL的两种方式JXL和POI

    JXL和POI导出数据方式的比较 POI支持excel2003和2007,而jxl只支持excel2003. 下面为测试代码: public class TestCondition { /** * 生 ...

  5. 从数据库导出数据到excel之POI操作

    项目说明: 1:数据库中有两张表,主键关联 2:根据条件查询数据 3:处理为需要的数据封装类型,然后传到导出excel的方法中 <--框架部署就不详谈了,用的spring框架--> 补充: ...

  6. NPOI导出数据到Excel

    NPOI导出数据到Excel   前言 Asp.net操作Excel已经是老生长谈的事情了,可下面我说的这个NPOI操作Excel,应该是最好的方案了,没有之一,使用NPOI能够帮助开发者在没有安装微 ...

  7. 一个方便且通用的导出数据到 Excel 的类库

    一个方便且通用的导出数据到 Excel 的类库 起源: 之前在做一个项目时,客户提出了许多的导出数据的需求: 导出用户信息 导出业务实体信息 各种查询都要能导出 导出的数据要和界面上看到的一致 可以分 ...

  8. 从数据库导出数据到excel之List<List<Object>>导出

    说明:有时候数据处理为List<List<Object>>更方便 姊妹篇:从数据库导出数据到excel之List<Map<>>导出 兄弟篇:从数据库导出 ...

  9. java代码导出数据到Excel、js导出数据到Excel(三)

     jsp内容忽略,仅写个出发按钮:          <button style="width: 100px" onclick="expertExcel()&quo ...

随机推荐

  1. 去除Vue在WebStorm中报命名空间的错误

    Preferences -> Editor -> Inspections找到XML,把 Unbound XML namespace prefix的勾去掉

  2. 【数据库】数据库的锁机制,MySQL中的行级锁,表级锁,页级锁

    转载:http://www.hollischuang.com/archives/914 数据库的读现象浅析中介绍过,在并发访问情况下,可能会出现脏读.不可重复读和幻读等读现象,为了应对这些问题,主流数 ...

  3. linux 的tee命令

    tee 如果你在linux下希望将程序或命令运行的信息,在输入到文件的同时,也能够显示在屏幕上,你可以考虑使用tee这个命令.举个例子,直接上图 这里我调用函数aaa来完成将结果输入到aaa.log里 ...

  4. C语言的输入输出操作函数小结

    一.scanf()&printf()函数 scanf() 函数用于从标准输入(键盘)读取并格式化, printf() 函数发送格式化输出到标准输出(屏幕).  scanf()函数原型为int ...

  5. CentOS7搭建solr7.2

    solr介绍 一.Solr它是一种开放源码的.基于 Lucene Java 的搜索服务器,易于加入到 Web 应用程序中. 二.Solr 提供了层面搜索(就是统计).命中醒目显示并且支持多种输出格式( ...

  6. DB2开发系列之四——触发器

    1.触发器类型 1)BEFORE 触发器:在对表插入或更新之前执行该触发器,允许使用CALL 和 SIGNAL SQL 语句: 2)BEFORE DELETE 触发器:在删除操作之前执行该触发器: 3 ...

  7. node.js应用脚手架:koa2、sequelize、mysql

    自制了一个 nodejs 应用的脚手架. 基于 koa2 的,所以需要保证 node 环境至少为 7.6.0 吸取了以前的踩坑教训,添加了守护进程,确保应用不会因为异常导致网站直接挂掉(使用了 for ...

  8. 阿尔法冲刺——Postmortem会议

    设想与目标 1.我们软件要解决什么问题?是否定义得很清楚?是否对典型用户和典型场景有清晰的描述? 这个问题,我们觉得我们的软件目标还是比较明确的,在SRS中也给出了典型用户和典型场景的清晰的描述. 2 ...

  9. Beta阶段敏捷冲刺报告-DAY2

    Beta阶段敏捷冲刺报告-DAY2 Scrum Meeting 敏捷开发日期 2017.11.3 会议时间 13:00 会议地点 微信群 参会人员 项目组全体成员 会议内容 打包问题修复, 爬虫优化, ...

  10. 【转载】NetFPGA-1G-CML从零开始环境配置

    ##环境 深度Linux ###环境配置 ```bash sudo apt-get install libsigc++ sudo apt-get install qgit sudo apt-get i ...