1. /**
  2. * 导出excel (HSSFWorkbook)
  3. */
  4. @GetMapping("/testExport")
  5. public void testExport1(HttpServletResponse response)
  6. {
  7. /** 第一步,创建一个Workbook,对应一个Excel文件 */
  8. HSSFWorkbook wb = new HSSFWorkbook();
  9.  
  10. /** 第二步,在Workbook中添加一个sheet,对应Excel文件中的sheet */
  11. HSSFSheet sheet = wb.createSheet("excel导出标题");
  12.  
  13. /** 第三步,设置样式以及字体样式*/
  14. HSSFCellStyle titleStyle = createTitleCellStyle(wb);
  15. HSSFCellStyle headerStyle = createHeadCellStyle(wb);
  16. HSSFCellStyle contentStyle = createContentCellStyle(wb);
  17.  
  18. /** 第四步,创建标题 ,合并标题单元格 */
  19. // 行号
  20. int rowNum = 0;
  21. // 创建第一页的第一行,索引从0开始
  22. HSSFRow row0 = sheet.createRow(rowNum++);
  23. row0.setHeight((short) 800);// 设置行高
  24.  
  25. String title = "excel导出标题";
  26. HSSFCell c00 = row0.createCell(0);
  27. c00.setCellValue(title);
  28. c00.setCellStyle(titleStyle);
  29. // 合并单元格,参数依次为起始行,结束行,起始列,结束列 (索引0开始)
  30. sheet.addMergedRegion(new CellRangeAddress(0, 0, 0, 6));//标题合并单元格操作,6为总列数
  31.  
  32. // 第二行
  33. HSSFRow row1 = sheet.createRow(rowNum++);
  34. row1.setHeight((short) 500);
  35. String[] row_first = {"填表单位:", "", "", "", "", " 2019年第2季度 ", ""};
  36. for (int i = 0; i < row_first.length; i++) {
  37. HSSFCell tempCell = row1.createCell(i);
  38. tempCell.setCellStyle(headerStyle);
  39. if (i == 0) {
  40. tempCell.setCellValue(row_first[i] + "测试单位");
  41. } else if (i == 5) {
  42. tempCell.setCellStyle(headerStyle);
  43. tempCell.setCellValue(row_first[i]);
  44. } else {
  45. tempCell.setCellValue(row_first[i]);
  46. }
  47. }
  48.  
  49. // 合并
  50. sheet.addMergedRegion(new CellRangeAddress(1, 1, 0, 4));
  51. sheet.addMergedRegion(new CellRangeAddress(1, 1, 5, 6));
  52.  
  53. //第三行
  54. HSSFRow row2 = sheet.createRow(rowNum++);
  55. row2.setHeight((short) 700);
  56. String[] row_second = {"名称", "采集情况", "", "", "登记情况", "", "备注"};
  57. for (int i = 0; i < row_second.length; i++) {
  58. HSSFCell tempCell = row2.createCell(i);
  59. tempCell.setCellValue(row_second[i]);
  60. tempCell.setCellStyle(headerStyle);
  61. }
  62.  
  63. // 合并
  64. sheet.addMergedRegion(new CellRangeAddress(2, 3, 0, 0));//名称
  65. sheet.addMergedRegion(new CellRangeAddress(2, 2, 1, 3));//采集情况
  66. sheet.addMergedRegion(new CellRangeAddress(2, 2, 4, 5));//登记情况
  67. sheet.addMergedRegion(new CellRangeAddress(2, 3, 6, 6));//备注
  68.  
  69. //第四行
  70. HSSFRow row3 = sheet.createRow(rowNum++);
  71. row3.setHeight((short) 700);
  72. String[] row_third = {"", "登记数(人)", "办证总数(人)", "办证率(%)", "登记户数(户)", "签订数(份)", ""};
  73. for (int i = 0; i < row_third.length; i++) {
  74. HSSFCell tempCell = row3.createCell(i);
  75. tempCell.setCellValue(row_third[i]);
  76. tempCell.setCellStyle(headerStyle);
  77. }
  78.  
  79. //循环每一行数据
  80. List<Map<String, Object>> dataList = new ArrayList<Map<String, Object>>(); //查询出来的数据
  81. Map<String,Object> map = new HashMap<String,Object>();
  82. map.put("name", "测试名称1");
  83. map.put("r1", "111");
  84. map.put("r2", "222");
  85. map.put("r3", "333");
  86. map.put("r4", "444");
  87. map.put("r5", "555");
  88. map.put("r6", "666");
  89. dataList.add(map);
  90. dataList.add(map);//加多一条list
  91.  
  92. for (Map<String, Object> excelData : dataList) {
  93. HSSFRow tempRow = sheet.createRow(rowNum++);
  94. tempRow.setHeight((short) 500);
  95. // 循环单元格填入数据
  96. for (int j = 0; j < 7; j++) {
  97. HSSFCell tempCell = tempRow.createCell(j);
  98. tempCell.setCellStyle(contentStyle);
  99. String tempValue;
  100. if (j == 0) {
  101. // 乡镇、街道名称
  102. tempValue = excelData.get("name").toString();
  103. } else if (j == 1) {
  104. // 登记数(人)
  105. tempValue = excelData.get("r1").toString();
  106. } else if (j == 2) {
  107. // 办证总数(人)
  108. tempValue = excelData.get("r2").toString();
  109. } else if (j == 3) {
  110. // 办证率(%)
  111. tempValue = excelData.get("r3").toString();
  112. } else if (j == 4) {
  113. // 登记户数(户)
  114. tempValue = excelData.get("r4").toString();
  115. } else if (j == 5) {
  116. // 签订数(份)
  117. tempValue = excelData.get("r5").toString();
  118. } else {
  119. // 备注
  120. tempValue = excelData.get("r6").toString();
  121. }
  122. tempCell.setCellValue(tempValue);
  123. }
  124. }
  125.  
  126. // 注释行
  127. HSSFRow remark = sheet.createRow(rowNum++);
  128. remark.setHeight((short) 500);
  129. String[] row_remark = {"注:表中的“办证率=办证总数÷登记数×100%”", "", "", "", "", "", ""};
  130. for (int i = 0; i < row_remark.length; i++) {
  131. HSSFCell tempCell = remark.createCell(i);
  132. if (i == 0) {
  133. tempCell.setCellStyle(headerStyle);
  134. } else {
  135. tempCell.setCellStyle(contentStyle);
  136. }
  137. tempCell.setCellValue(row_remark[i]);
  138. }
  139. int remarkRowNum = dataList.size() + 4;
  140. sheet.addMergedRegion(new CellRangeAddress(remarkRowNum, remarkRowNum, 0, 6));//注释行合并单元格
  141.  
  142. // 尾行
  143. HSSFRow foot = sheet.createRow(rowNum++);
  144. foot.setHeight((short) 500);
  145. String[] row_foot = {"审核人:", "", "填表人:", "", "填表时间:", "", ""};
  146. for (int i = 0; i < row_foot.length; i++) {
  147. HSSFCell tempCell = foot.createCell(i);
  148. tempCell.setCellStyle(contentStyle);
  149. if (i == 0) {
  150. tempCell.setCellValue(row_foot[i] + "张三");
  151. } else if (i == 2) {
  152. tempCell.setCellValue(row_foot[i] + "李四");
  153. } else if (i == 4) {
  154. tempCell.setCellValue(row_foot[i] + "xxxx");
  155. } else {
  156. tempCell.setCellValue(row_foot[i]);
  157. }
  158. }
  159. int footRowNum = dataList.size() + 5;
  160. // 注
  161. sheet.addMergedRegion(new CellRangeAddress(footRowNum, footRowNum, 0, 1));
  162. sheet.addMergedRegion(new CellRangeAddress(footRowNum, footRowNum, 2, 3));
  163. sheet.addMergedRegion(new CellRangeAddress(footRowNum, footRowNum, 4, 6));
  164.  
  165. //导出
  166. // HttpServletResponse response = this.getResponse();
  167. String fileName = "报表名称.xls";
  168.  
  169. try {
  170. response.setCharacterEncoding("UTF-8");
  171. response.setHeader("content-Type", "application/vnd.ms-excel");
  172. response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(fileName, "UTF-8"));
  173. OutputStream stream = response.getOutputStream();
  174. if (null != wb && null != stream) {
  175. wb.write(stream);// 将数据写出去
  176. wb.close();
  177. stream.close();
  178. }
  179. } catch (Exception e) {
  180. e.printStackTrace();
  181. }
  182. }

导出结果如图

POI导出复杂Excel,合并单元格(2)的更多相关文章

  1. Java poi导出设置 Excel某些单元格不可编辑

    小白的总结,大神勿喷:需要转载请说明出处,如果有什么问题,欢迎留言 一.需求: 1.某一列 .某一行或某些单元格不可编辑,其他列可以编辑 二.期间遇到的问题 1.无法设置成不可编辑 2.设置为不可编辑 ...

  2. asp.net C#取Excel 合并单元格内容

    asp教程.net c#取excel 合并单元格内容读取excel数据,填充dataset// 连接字符串 string xlspath = server.mappath("~/www.11 ...

  3. 使用POI创建word表格合并单元格兼容wps

    poi创建word表格合并单元格代码如下: /** * @Description: 跨列合并 */ public void mergeCellsHorizontal(XWPFTable table, ...

  4. java poi导出Excel合并单元格并设置边框

    import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermodel.HSSFCellStyle; i ...

  5. poi导出excel合并单元格(包括列合并、行合并)

    1 工程所需jar包如下:commons-codec-1.5.jarcommons-logging-1.1.jarlog4j-1.2.13.jarjunit-3.8.1.jarpoi-3.9-2012 ...

  6. poi excel 合并单元格

    结论:final CellRangeAddress cra = new CellRangeAddress(rowId, rowId + rowSkip,        colId, colId + c ...

  7. 前端Excel表格导入导出,包括合并单元格,表格自定义样式等

    表格数据导入 读取导入Excel表格数据这里采用的是 xlsx 插件 npm i xlsx 读取excel需要通过 XLSX.read(data, {type: type}) 方法来实现,返回一个叫W ...

  8. npoi导出excel合并单元格

    需要引用NPOI.dll程序集和Ionic.Zip.dll程序集 string[] headerRowName = { "序号", "地市", "镇街 ...

  9. NPOI之Excel——合并单元格、设置样式、输入公式、设置筛选等

    首先建立一个空白的工作簿用作测试,并在其中建立空白工作表,在表中建立空白行,在行中建立单元格,并填入内容: //建立空白工作簿 IWorkbook workbook = new HSSFWorkboo ...

  10. NPOI之Excel——合并单元格、设置样式、输入公式

    首先建立一个空白的工作簿用作测试,并在其中建立空白工作表,在表中建立空白行,在行中建立单元格,并填入内容: //建立空白工作簿 IWorkbook workbook = new HSSFWorkboo ...

随机推荐

  1. JavaWeb和WebGIS学习笔记(七)——MapGuide Open Source安装、配置以及MapGuide Maestro发布地图——超详细!目前最保姆级的MapGuide上手指南!

    JavaWeb和WebGIS学习笔记(七)--MapGuide Open Source安装.配置以及MapGuide Maestro发布地图 超详细!目前最保姆级的MapGuide上手指南! 系列链接 ...

  2. Prim 最小生成树 图解

    ​ 什么是生成树 子图:G=<V,E>,G'=<V', E'>,为两个图(V为点集,即图中点的集合,E为边集),如果V'是V的子集且E'是E的子集,则G'是G的子图. 如果V' ...

  3. 架构师必备:Redis的几种集群方案

    结论 有以下几种Redis集群方案,先说结论: Redis cluster:应当优先考虑使用Redis cluster. codis:旧项目如果仍在使用codis,可继续使用,但也推荐迁移到Redis ...

  4. 原来 Linux 日志文件系统是这样工作的~

    关注「开源Linux」,选择"设为星标" 回复「学习」,有我为您特别筛选的学习资料~ 作者:Linux Performance 链接:http://linuxperf.com/?p ...

  5. APP应用前端开发

    1.开发手机APP前端要重视meta标签的编写: 2.注意HTML5标签在前端开发中的使用: 3.前端制作要舍弃CSS float属性(可flex布局),用绝对定位不利于页面布局的扩展: 4.APP前 ...

  6. django的下载安装,目录结构的介绍,简单的django应用

    1.django的下载安装 pip3 install django==1.11.9 2.django的创建 1.在windows的cmd窗口下 1.1创建django项目 django-admin s ...

  7. 关于扑克牌的一些讨论——《Fluent Python 2》读书笔记

    一.说明 参考资料为维基百科的 Playing Card 词条,非严肃性论证,只是对代码为什么这么写做讨论. 二.扑克牌的起源 import collections Card = collection ...

  8. git 本地项目关联新repo

    git initgit remote add origin repo-url git pull origin master --allow-unrelated-histories git add . ...

  9. arts-week12

    Algorithm 69. Sqrt(x) - LeetCode Review Cloudflare goes InterPlanetary - Introducing Cloudflare's IP ...

  10. Android 12(S) 图像显示系统 - GraphicBuffer同步机制 - Fence

    必读: Android 12(S) 图像显示系统 - 开篇 一.前言 前面的文章中讲解Android BufferQueue的机制时,有遇到过Fence,但没有具体讲解.这篇文章,就针对Fence这种 ...