POI-java下载excel-HSSFWorkbook
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import java.io.PrintWriter;
import java.net.URLEncoder;
import javax.servlet.ServletException;
import javax.servlet.annotation.WebServlet;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
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.HSSFDataFormat;
import org.apache.poi.hssf.usermodel.HSSFFont;
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;
/**
* Servlet implementation class GetSmariExcelServlet
*/
@WebServlet("/GetSmariExcelServlet")
public class GetSmariExcelServlet extends HttpServlet {
private static final long serialVersionUID = 1L;
/**
* @see HttpServlet#HttpServlet()
*/
public GetSmariExcelServlet() {
super();
// TODO Auto-generated constructor stub
}
/**
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)
*/
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
String shellParam=maker+" "+jigobu+" "+div+" "+dataFlg+" "+stime+" "+etime;
String shellName="/home/trial/AP/KIGYO_KARUTE/CGI/SUMMARY_DETAIL.SEARCH";
GetJsonAndData get = new GetJsonAndData();
String result = get.getDataString(shellName, shellParam);
StringBuilder resultJson = null;
GetSmariExcelServlet me=new GetSmariExcelServlet();
ExcelName="サマリ";
response.setContentType("text/json; charset=utf-8");
HSSFWorkbook workbook = me.getExcelFile(result); //拿到 创建好并且填充好td 的workbook
response.setContentType("application/ms-excel;charset=UTF-8");//
response.addHeader("Content-Disposition", "attachment; filename="
+ URLEncoder.encode(ExcelName, "utf-8") + ".xls");//
OutputStream ouputStream = response.getOutputStream(); //拿到response的输出流
workbook.write(ouputStream); //workbook.write(输出流--输出的方向);
ouputStream.flush(); //提交
ouputStream.close(); //关闭,返回页面 ,下载excel
}
/**
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response)
*/
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {
// TODO Auto-generated method stub
doGet(request,response);
}
/**
*用字符串拼html文 --往excel中写入内容
*/
private StringBuilder smariTable(String result,String shellParam){
String[] resultR = result.split("\n");
StringBuilder html=new StringBuilder();
html.append("<html>");
html.append("<head>");
html.append("<style>");
html.append("td{border:1px solid #A3C0E8;overflow:hidden;white-space:nowrap;color:black;text-align:center;}");
html.append(".htd{background-color:#00619C;color:#FFFFFF}");
html.append(".std{background-color:#FCE4D6;color:#413B38}");
html.append("</style></head><body><table>");
//....
html.append("<tr>");
html.append("<td class='htd' rowspan='3'>クラスター企業</td>");
//....
html.append("</tr>");
String[] head=resultR[0].split(" ");
html.append("<tr>");
for (int i=1;i<collen-1;i++) {
if (i<3||i==(3+2*mcount)||i==(4+4*mcount)||i==(5+4*mcount)||i==(6+6*mcount)||i==(7+6*mcount)) {
}else{
html.append("<td class='htd'>"+head[i+1]+"</td>");
}
}
html.append("</tr>");
for (int i=1;i<resultR.length;i++) {
html.append("<tr>");
//....
html.append("</tr>");
}
html.append("</table></body></html>");
return html;
}
/**
*用POI的HSSFWorkbook生成excel文件
*/
public HSSFWorkbook getExcelFile(String result) {
HSSFWorkbook workbook = new HSSFWorkbook(); //
HSSFSheet sheet = workbook.createSheet("サマリ"); // workbook.createSheet("excel中工作表的名字")
sheet.createFreezePane( 2, 3, 3, 4); //冻结的列以及行
//createFreezePane(p1要冻结的列数,p2要冻结的行数,p3右侧窗格从第几列开始显示,p4下侧窗格从第几行开始显示); 其中 p3>p1,p4>p2,否则异常
//合并单元格 第一个和第二个参数表示开始行和结束行,第三和第四个参数表示开始列和结束列
//sheet.addMergedRegion(new CellRangeAddress(0,0,0,8));
sheet.addMergedRegion(new CellRangeAddress(0,0,2*m+3,4*m+4));
//合并单元格 addMergedRegion(new CellRangeAddress(起始行,起始列,结束行,结束列));
//表头白色字体
HSSFFont FontWhiteBold = workbook.createFont();//创建字体样式
FontWhiteBold.setFontHeightInPoints((short)12);//设置字体大小
FontWhiteBold.setFontName("Meiryo UI");//设置字体
FontWhiteBold.setColor(HSSFColor.WHITE.index);//设置默认字体颜色白色
FontWhiteBold.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);//正常字体 ,还有加粗字体等
//表头样式
HSSFCellStyle headStyle = (HSSFCellStyle) workbook.createCellStyle();//创建单元格样式
headStyle.setBorderBottom((short) 1);//设置边框 -- setBorderBottom等函数的参数都为short,要强制转化int型数据为short
headStyle.setBorderLeft((short) 1);//设置边框
headStyle.setBorderRight((short) 1);//设置边框
headStyle.setBorderTop((short) 1);//设置边框
headStyle.setLeftBorderColor(HSSFColor.BLUE_GREY.index);
headStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);//单元格内容居中
headStyle.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//单元格内容垂直居中
headStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);//背景
headStyle.setFillForegroundColor(HSSFColor.ROYAL_BLUE.index);//设置背景色
headStyle.setFont(FontWhiteBold);//字体--setFont(定义好的字体类);
sheet.setColumnWidth(0, 8000);//设置第一列的列宽
HSSFRow headRow0 = sheet.createRow(0); //创建第一行 tr
HSSFCell mes_cell = (HSSFCell) headRow0.createCell(i); //第一行的第一个单元格 td
mes_cell.setCellValue(head0[i]); //td的值
mes_cell.setCellStyle(headStyle); //td样式
HSSFRow headRow1 = sheet.createRow(i);
HSSFCell mes_cell = (HSSFCell) headRow1.createCell(j);
mes_cell.setCellValue(head1[i]);
mes_cell.setCellStyle(headStyle);
sheet.groupColumn(2, m); //分组 -- 多列多行 点-收缩,+伸开的效果 前闭(后-1)开
sheet.groupColumn(2+m, 2*m);
sheet.groupColumn(2*m+3, 3*m+1);
sheet.groupColumn(3*m+3, 4*m+1);
sheet.groupColumn(4*m+5, 5*m+3);
sheet.groupColumn(5*m+5, 6*m+3);
sheet.setColumnGroupCollapsed(2, true); //分的组 收缩起来
sheet.setColumnGroupCollapsed(2+m, true);
sheet.setColumnGroupCollapsed(2*m+3, true);
sheet.setColumnGroupCollapsed(3*m+3, true);
sheet.setColumnGroupCollapsed(4*m+5, true);
sheet.setColumnGroupCollapsed(5*m+5, true);
return workbook;
}
}
POI-java下载excel-HSSFWorkbook的更多相关文章
- java的poi技术下载Excel模板上传Excel读取Excel中内容(SSM框架)
使用到的jar包 JSP: client.jsp <%@ page language="java" contentType="text/html; charset= ...
- 【小坑】java下载excel文件
excel文件的导入导出是很常见的功能,这次做了个下载的功能,踩了一些坑,记下来避免以后重复踩…… 1.inputstream序列化问题 Could not write JSON document: ...
- java下载Excel模板(工具类)
一次文件下载记录 一次不成熟的文件下载操作记录,希望能对需要的人有所帮助. 1.前端代码 $("#downloadModel").click(function(){ var mod ...
- java 下载Excel模板
前端: JSP: <div id="insertBtn" class="MyCssBtn leftBtn" onclick="download( ...
- java下载excel,excel从数据库获取数据
<!-- poi --> <dependency> <groupId>org.apache.poi</groupId> <artifactId&g ...
- poi java读取excel文件
官网使用学习链接地址 http://poi.apache.org/components/spreadsheet/quick-guide.html
- java的poi技术读取Excel数据到MySQL
这篇blog是介绍java中的poi技术读取Excel数据,然后保存到MySQL数据中. 你也可以在 : java的poi技术读取和导入Excel了解到写入Excel的方法信息 使用JXL技术可以在 ...
- java的poi技术写Excel的Sheet
在这之前写过关于java读,写Excel的blog如下: Excel转Html java的poi技术读,写Excel[2003-2007,2010] java的poi技术读取Excel[2003-20 ...
- java的poi技术读取Excel[2003-2007,2010]
这篇blog主要是讲述java中poi读取excel,而excel的版本包括:2003-2007和2010两个版本, 即excel的后缀名为:xls和xlsx. 读取excel和MySQL相关: ja ...
- java写入excel文件poi
java写入excel文件 java写入excel文件poi,支持xlsx与xls,没有文件自动创建 package com.utils; import java.io.File; import ja ...
随机推荐
- vscode jsx语法自动补全html代码
1.点击文件——>首选项——>设置 注意:只有在js文件里的jsx才可以自动补全,html文件里的jsx不能.
- FusionCharts可使用JavaScript渲染iPhone/iPod/iPad图表
FusionCharts使用JavaScript: FusionCharts允许用户创建建立JavaScript图表(也就是web上的HTML5 /Canvas图表).这个特性允许用户在不支持Flas ...
- 修改Oracle环境变量$PATH
此次在创建公司的Oracle 标准化应用时,提到了添加$PATH,但没有发现对我很符合我的现况的方法,现记录下此次添加$PATH的方法: 首先查看$PATH中是否已存在我们需要的路径: 执行指令ech ...
- C# 常见的字符串操作
例1: 遍历字符串中的每一个字符: string src = "aa-b - c-a - d-e- d-e- a- a-b-cc"; foreach(char c in src) ...
- Hyper-V 2016 配置管理系列(部署篇)
Hyper主机前提准备以后,我们开始Hyper-V Cluster 群集配置 准备验证Cluster 群集 : 1)打开群集管理器,点击"validate Configuration&quo ...
- Sonar服务器搭建
Sonar服务器搭建 Sonar概述 Sonar 是一个用于代码质量管理的开放平台.通过插件机制,Sonar 可以集成不同的测试工具,代码分析工具,以及持续集成工具.与持续集成工具(例如 Hudson ...
- 【BZOJ2049】[SDOI2008] Cave 洞穴勘测(LCT维护连通性)
点此看题面 大致题意: 有\(n\)个洞穴,\(3\)种操作:连一条边,删一条边,询问两点是否联通. \(LCT\)维护连通性 这道题应该是\(LCT\)动态维护连通性的一道模板题. 考虑将\(x\) ...
- iOS Dispatch_sync 阻塞线程的原因
大家的知道在主队列上使用dispatch_sync(), - (void)testSyncMainThread { dispatch_queue_t main = dispatch_get_main_ ...
- 使TextBox的内容换行
首先你把TextBox控件的MultiLine属性设置为True,然后把TextBox控件的Text属性根据程序需要,在需要换行的地方加入\r\n这样就可实现换行了
- Apache 配置默认编码
找到apache配置文件 httpd.conf ,找到以下内容 # # Specify a default charset for all content served; this enables # ...