1. public ActionResult excelPrint() {
  2. HSSFWorkbook workbook = new HSSFWorkbook();// 创建一个Excel文件
  3. HSSFSheet sheet = workbook.createSheet();// 创建一个Excel的Sheet
  4. sheet.createFreezePane(1, 3);// 冻结
  5. // 设置列宽
  6. sheet.setColumnWidth(0, 1000);
  7. sheet.setColumnWidth(1, 3500);
  8. sheet.setColumnWidth(2, 3500);
  9. sheet.setColumnWidth(3, 6500);
  10. sheet.setColumnWidth(4, 6500);
  11. sheet.setColumnWidth(5, 6500);
  12. sheet.setColumnWidth(6, 6500);
  13. sheet.setColumnWidth(7, 2500);
  14. // Sheet样式
  15. HSSFCellStyle sheetStyle = workbook.createCellStyle();
  16. // 背景色的设定
  17. sheetStyle.setFillBackgroundColor(HSSFColor.GREY_25_PERCENT.index);
  18. // 前景色的设定
  19. sheetStyle.setFillForegroundColor(HSSFColor.GREY_25_PERCENT.index);
  20. // 填充模式
  21. sheetStyle.setFillPattern(HSSFCellStyle.FINE_DOTS);
  22. // 设置列的样式
  23. for (int i = 0; i <= 14; i++) {
  24. sheet.setDefaultColumnStyle((short) i, sheetStyle);
  25. }
  26. // 设置字体
  27. HSSFFont headfont = workbook.createFont();
  28. headfont.setFontName("黑体");
  29. headfont.setFontHeightInPoints((short) 22);// 字体大小
  30. headfont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);// 加粗
  31. // 另一个样式
  32. HSSFCellStyle headstyle = workbook.createCellStyle();
  33. headstyle.setFont(headfont);
  34. headstyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 左右居中
  35. headstyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);// 上下居中
  36. headstyle.setLocked(true);
  37. headstyle.setWrapText(true);// 自动换行
  38. // 另一个字体样式
  39. HSSFFont columnHeadFont = workbook.createFont();
  40. columnHeadFont.setFontName("宋体");
  41. columnHeadFont.setFontHeightInPoints((short) 10);
  42. columnHeadFont.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
  43. // 列头的样式
  44. HSSFCellStyle columnHeadStyle = workbook.createCellStyle();
  45. columnHeadStyle.setFont(columnHeadFont);
  46. columnHeadStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 左右居中
  47. columnHeadStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);// 上下居中
  48. columnHeadStyle.setLocked(true);
  49. columnHeadStyle.setWrapText(true);
  50. columnHeadStyle.setLeftBorderColor(HSSFColor.BLACK.index);// 左边框的颜色
  51. columnHeadStyle.setBorderLeft((short) 1);// 边框的大小
  52. columnHeadStyle.setRightBorderColor(HSSFColor.BLACK.index);// 右边框的颜色
  53. columnHeadStyle.setBorderRight((short) 1);// 边框的大小
  54. columnHeadStyle.setBorderBottom(HSSFCellStyle.BORDER_THIN); // 设置单元格的边框为粗体
  55. columnHeadStyle.setBottomBorderColor(HSSFColor.BLACK.index); // 设置单元格的边框颜色
  56. // 设置单元格的背景颜色(单元格的样式会覆盖列或行的样式)
  57. columnHeadStyle.setFillForegroundColor(HSSFColor.WHITE.index);
  58. HSSFFont font = workbook.createFont();
  59. font.setFontName("宋体");
  60. font.setFontHeightInPoints((short) 10);
  61. // 普通单元格样式
  62. HSSFCellStyle style = workbook.createCellStyle();
  63. style.setFont(font);
  64. style.setAlignment(HSSFCellStyle.ALIGN_LEFT);// 左右居中
  65. style.setVerticalAlignment(HSSFCellStyle.VERTICAL_TOP);// 上下居中
  66. style.setWrapText(true);
  67. style.setLeftBorderColor(HSSFColor.BLACK.index);
  68. style.setBorderLeft((short) 1);
  69. style.setRightBorderColor(HSSFColor.BLACK.index);
  70. style.setBorderRight((short) 1);
  71. style.setBorderBottom(HSSFCellStyle.BORDER_THIN); // 设置单元格的边框为粗体
  72. style.setBottomBorderColor(HSSFColor.BLACK.index); // 设置单元格的边框颜色.
  73. style.setFillForegroundColor(HSSFColor.WHITE.index);// 设置单元格的背景颜色.
  74. // 另一个样式
  75. HSSFCellStyle centerstyle = workbook.createCellStyle();
  76. centerstyle.setFont(font);
  77. centerstyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 左右居中
  78. centerstyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);// 上下居中
  79. centerstyle.setWrapText(true);
  80. centerstyle.setLeftBorderColor(HSSFColor.BLACK.index);
  81. centerstyle.setBorderLeft((short) 1);
  82. centerstyle.setRightBorderColor(HSSFColor.BLACK.index);
  83. centerstyle.setBorderRight((short) 1);
  84. centerstyle.setBorderBottom(HSSFCellStyle.BORDER_THIN); // 设置单元格的边框为粗体
  85. centerstyle.setBottomBorderColor(HSSFColor.BLACK.index); // 设置单元格的边框颜色.
  86. centerstyle.setFillForegroundColor(HSSFColor.WHITE.index);// 设置单元格的背景颜色.
  87. try {
  88. // 创建第一行
  89. HSSFRow row0 = sheet.createRow(0);
  90. // 设置行高
  91. row0.setHeight((short) 900);
  92. // 创建第一列
  93. HSSFCell cell0 = row0.createCell(0);
  94. cell0.setCellValue(new HSSFRichTextString("中非发展基金投资项目调度会工作落实情况对照表"));
  95. cell0.setCellStyle(headstyle);
  96. CellRangeAddress range = new CellRangeAddress(0, 0, 0, 7);
  97. sheet.addMergedRegion(range);
  98. // 创建第二行
  99. HSSFRow row1 = sheet.createRow(1);
  100. HSSFCell cell1 = row1.createCell(0);
  101. cell1.setCellValue(new HSSFRichTextString("本次会议时间:2009年8月31日       前次会议时间:2009年8月24日"));
  102. cell1.setCellStyle(centerstyle);
  103. // 合并单元格
  104. range = new CellRangeAddress(1, 2, 0, 7);
  105. sheet.addMergedRegion(range);
  106. // 第三行
  107. HSSFRow row2 = sheet.createRow(3);
  108. row2.setHeight((short) 750);
  109. HSSFCell cell = row2.createCell(0);
  110. cell.setCellValue(new HSSFRichTextString("责任者"));
  111. cell.setCellStyle(columnHeadStyle);
  112. cell = row2.createCell(1);
  113. cell.setCellValue(new HSSFRichTextString("成熟度排序"));
  114. cell.setCellStyle(columnHeadStyle);
  115. cell = row2.createCell(2);
  116. cell.setCellValue(new HSSFRichTextString("事项"));
  117. cell.setCellStyle(columnHeadStyle);
  118. cell = row2.createCell(3);
  119. cell.setCellValue(new HSSFRichTextString("前次会议要求/n/新项目的项目概要"));
  120. cell.setCellStyle(columnHeadStyle);
  121. cell = row2.createCell(4);
  122. cell.setCellValue(new HSSFRichTextString("上周工作进展"));
  123. cell.setCellStyle(columnHeadStyle);
  124. cell = row2.createCell(5);
  125. cell.setCellValue(new HSSFRichTextString("本周工作计划"));
  126. cell.setCellStyle(columnHeadStyle);
  127. cell = row2.createCell(6);
  128. cell.setCellValue(new HSSFRichTextString("问题和建议"));
  129. cell.setCellStyle(columnHeadStyle);
  130. cell = row2.createCell(7);
  131. cell.setCellValue(new HSSFRichTextString("备 注"));
  132. cell.setCellStyle(columnHeadStyle);
  133. // 访问数据库,得到数据集
  134. List deitelVOList = getEntityManager().queryDeitelVOList();
  135. int m = 4;
  136. int k = 4;
  137. for (int i = 0; i < deitelVOList.size(); i++) {
  138. DeitelVO vo = deitelVOList.get(i);
  139. String dname = vo.getDname();
  140. List workList = vo.getWorkInfoList();
  141. HSSFRow row = sheet.createRow(m);
  142. cell = row.createCell(0);
  143. cell.setCellValue(new HSSFRichTextString(dname));
  144. cell.setCellStyle(centerstyle);
  145. // 合并单元格
  146. range = new CellRangeAddress(m, m + workList.size() - 1, 0, 0);
  147. sheet.addMergedRegion(range);
  148. m = m + workList.size();
  149. for (int j = 0; j < workList.size(); j++) {
  150. Workinfo w = workList.get(j);
  151. // 遍历数据集创建Excel的行
  152. row = sheet.getRow(k + j);
  153. if (null == row) {
  154. row = sheet.createRow(k + j);
  155. }
  156. cell = row.createCell(1);
  157. cell.setCellValue(w.getWnumber());
  158. cell.setCellStyle(centerstyle);
  159. cell = row.createCell(2);
  160. cell.setCellValue(new HSSFRichTextString(w.getWitem()));
  161. cell.setCellStyle(style);
  162. cell = row.createCell(3);
  163. cell.setCellValue(new HSSFRichTextString(w.getWmeting()));
  164. cell.setCellStyle(style);
  165. cell = row.createCell(4);
  166. cell.setCellValue(new HSSFRichTextString(w.getWbweek()));
  167. cell.setCellStyle(style);
  168. cell = row.createCell(5);
  169. cell.setCellValue(new HSSFRichTextString(w.getWtweek()));
  170. cell.setCellStyle(style);
  171. cell = row.createCell(6);
  172. cell.setCellValue(new HSSFRichTextString(w.getWproblem()));
  173. cell.setCellStyle(style);
  174. cell = row.createCell(7);
  175. cell.setCellValue(new HSSFRichTextString(w.getWremark()));
  176. cell.setCellStyle(style);
  177. }
  178. k = k + workList.size();
  179. }
  180. // 列尾
  181. int footRownumber = sheet.getLastRowNum();
  182. HSSFRow footRow = sheet.createRow(footRownumber + 1);
  183. HSSFCell footRowcell = footRow.createCell(0);
  184. footRowcell.setCellValue(new HSSFRichTextString("                    审  定:XXX      审  核:XXX     汇  总:XX"));
  185. footRowcell.setCellStyle(centerstyle);
  186. range = new CellRangeAddress(footRownumber + 1, footRownumber + 1, 0, 7);
  187. sheet.addMergedRegion(range);
  188. HttpServletResponse response = getResponse();
  189. HttpServletRequest request = getRequest();
  190. String filename = "未命名.xls";//设置下载时客户端Excel的名称
  191. // 请见:http://zmx.javaeye.com/blog/622529
  192. filename = Util.encodeFilename(filename, request);
  193. response.setContentType("application/vnd.ms-excel");
  194. response.setHeader("Content-disposition", "attachment;filename=" + filename);
  195. OutputStream ouputStream = response.getOutputStream();
  196. workbook.write(ouputStream);
  197. ouputStream.flush();
  198. ouputStream.close();
  199. catch (Exception e) {
  200. e.printStackTrace();
  201. }
  202. return null;
  203. }

HSSFWorkbook的更多相关文章

  1. HSSFWorkBooK用法

    public ActionResult excelPrint() { HSSFWorkbook workbook = new HSSFWorkbook();// 创建一个Excel文件 HSSFShe ...

  2. POI Workbook接口和HSSFWorkbook对象和XSSFWorkbook对象操作相应excel版本

    由于HSSFWorkbook只能操作excel2003一下版本,XSSFWorkbook只能操作excel2007以上版本,所以利用Workbook接口创建对应的对象操作excel来处理兼容性 @Te ...

  3. 数据以Excel形式导出导服务器,再将文件读取到客户端另存 以HSSFWorkbook方式实现

    public void exportExcel(List<P2pInfo> repayXist,HttpServletRequest request,HttpServletResponse ...

  4. HSSFWorkbook和XSSFWorkbook的区别

    HSSFWorkbook读取97-2003格式 ,XSSFWorkbook读取2007-2013格式 /** * 读取97-2003格式 * @param filePath 文件路径 * @throw ...

  5. 自己写的POIUtil,主要解决从不同的HSSFWorkbook复制sheet以及根据单元格插入图片等

    复制sheet的原始代码网上找的,但是小问题很多,然后自己动手改了一下: 根据单元格信息动态插入图片,如果单元格有文字,图片的位置会在文字之后,如果同样的位置已有图片则会往下插入. import or ...

  6. HSSFWorkbook 导出excel java

    public String exportExcelList(){ //创建webbook,对应一个excel文件 HSSFWorkbook wb = new HSSFWorkbook(); //在we ...

  7. HSSFWorkbook操作excel读写

    //exlel读操作 MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request; Ite ...

  8. 关于poi导出excel三种方式HSSFWorkbook,SXSSFWorkbook,csv的总结

    poi导出excel最常用的是第一种方式HSSFWorkbook,不过这种方式数据量大的话会产生内存溢出问题,SXSSFWorkbook是一种大数据量导出格式,csv是另一种excel导出的一种轻快的 ...

  9. 关于poi导出excel方式HSSFWorkbook(xls).XSSFWorkbook(xlsx).SXSSFWorkbook.csv的总结

    1.HSSFWorkbook(xls) import org.apache.poi.hssf.usermodel.HSSFCell; import org.apache.poi.hssf.usermo ...

  10. 项目总结06:Java Excel文件导入功能HSSFWorkbook(xls)和 XSSFWorkbook (xlsx)

    项目中碰到Excel文件打入数据功能Mark一下 package com.blue.pem.client.util; import java.io.File; import java.io.FileI ...

随机推荐

  1. [HDNOIP2017提高组]题解

    (送给外省的同学们:HD = 海淀) [HDNOIP201701]小鱼干 试题描述 小喵喵有 n 个小鱼干排成一列,其中第 i 个小鱼干有两种属性,美味度 ai 和特殊度 bi. 现在小喵喵要吃掉一些 ...

  2. 刷题总结——棘手的操作(bzoj2333)

    题目: 题目背景 SCOI2011 DAY2 T1 题目描述 有 N 个节点,标号从 1 到 N ,这 N 个节点一开始相互不连通.第i个节点的初始权值为 a[i] ,接下来有如下一些操作:U x y ...

  3. CentOS7 Failed to start iptables.解决方法

    Shit, CentOS怎么这么多bug.... 公司机房周日突然掉电,之前的Openstack环境就不能用了. 重新Run了一遍安装脚本,发现这个错误: iptables 咋又起不来了呢..... ...

  4. NIO系列1:框架拆解

    最近一年用NIO写了不少网络程序,也研究了一些开源NIO网络框架netty.mina等,总结了一下NIO的架构特点. 无论是netty还是mina它们都在java原生NIO的基础上进行了完善的封装,虽 ...

  5. 创建SVN 本地服务器

    svnserve具体配置如下,主要是将 password-db 前的#号去掉,即去掉注释使其生效 passwd具体配置如下,主要是新增自己需要的账号和密码,也可以将原有的账号去掉注释使用 authz ...

  6. linux信号------探步

    前言 Linux以进程为单位来执行程序.我们可以 将计算机看作一个大楼,内核(kernel)是大楼的管理员,进程是大楼的房客.每个进程拥有一个独立的房间(属于进程的内存空间),而每个房间都是不允 许该 ...

  7. 升级 GCC 支持C++11 或 configure: error: *** A compiler with support for C++11 language features is required.

    configure: error: *** A compiler with support for C++11 language features is required. 参考链接: (1)升级 G ...

  8. hdu 5444(构造二叉树然后遍历)

    Elven Postman Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

  9. [Python Cookbook] Numpy: How to Apply a Function to 1D Slices along the Given Axis

    Here is a function in Numpy module which could apply a function to 1D slices along the Given Axis. I ...

  10. 【ZJOI2017】树状数组

    题目描述 漆黑的晚上,九条可怜躺在床上辗转反侧.难以入眠的她想起了若干年前她的一次悲惨的 OI 比赛经历.那是一道基础的树状数组题. 给出一个长度为 $n$ 的数组 $A$,初始值都为 $0$,接下来 ...