在做excel导出的时候,有两个选择摆在面前,我先是做了一个js的,但不支持FF,而且要求浏览器降低安全性,才可以。前几天看了js导出pdf支持FF,估计js导出excel也能支持FF,类似的原理。不过用户体验不好,还是决定采用服务器生成的方式。
这个时候有两个选择,一个是poi,另一个是jxl。我选择了poi,因为对它比较熟悉。据说jxl也是很好用的。
这其中没什么好说的。有一点格式控制,花了一点功夫,比如合并单元格之类,字体,色彩等样式。
代码如下:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<%@page import="org.apache.poi.hssf.usermodel.*"%>
<%@ page import="org.apache.poi.hssf.util.Region" %>
<%
//获取参数
String searcWord = request.getParameter("searchword");
if (null == searcWord || "".equals(searcWord.trim())) {
return;
} else {
searcWord=new String(searcWord.getBytes("iso-8859-1"),"UTF-8");
Connection con = SQLServices.getConnection();
ResultSet rs = con.executeSelect("qsssd",
searcWord, false);
if (null == rs) {
return;
} else {
//开始构造excel;
try {
// 创建新的Excel 工作簿
HSSFWorkbook workbook = new HSSFWorkbook();
// 在Excel工作簿中建一工作表,其名为缺省值。
// 也可以指定工作表的名字。
HSSFSheet sheet = workbook.createSheet("Report");
//==========================设置字体样式start==========================
HSSFCellStyle cs = workbook.createCellStyle();
HSSFFont font = workbook.createFont();
font.setFontName("宋体");// 设置字体
font.setFontHeightInPoints((short) 18);// 字体大小
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);// 加粗
cs.setFont(font);
cs.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 水平居中
cs.setBorderBottom(HSSFCellStyle.BORDER_THIN);// 下边框
cs.setBorderLeft(HSSFCellStyle.BORDER_THIN);// 左边框
cs.setBorderRight(HSSFCellStyle.BORDER_THIN);// 右边框
cs.setBorderTop(HSSFCellStyle.BORDER_THIN);// 上边框
HSSFCellStyle cs2 = workbook.createCellStyle();
HSSFFont font2 = workbook.createFont();
font2.setFontName("宋体");// 设置字体
font2.setFontHeightInPoints((short) 12);// 字体大小
font2.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);// 加粗
cs2.setFont(font2);
cs2.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 水平居中
cs2.setBorderBottom(HSSFCellStyle.BORDER_THIN);// 下边框
cs2.setBorderLeft(HSSFCellStyle.BORDER_THIN);// 左边框
cs2.setBorderRight(HSSFCellStyle.BORDER_THIN);// 右边框
cs2.setBorderTop(HSSFCellStyle.BORDER_THIN);// 上边框
HSSFCellStyle cs3 = workbook.createCellStyle();
HSSFFont font3 = workbook.createFont();
font3.setFontName("宋体");
font3.setFontHeightInPoints((short) 10);
cs3.setFont(font3);
cs3.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 水平居中
cs3.setBorderBottom(HSSFCellStyle.BORDER_THIN);// 下边框
cs3.setBorderLeft(HSSFCellStyle.BORDER_THIN);// 左边框
cs3.setBorderRight(HSSFCellStyle.BORDER_THIN);// 右边框
cs3.setBorderTop(HSSFCellStyle.BORDER_THIN);// 上边框
HSSFCellStyle cs4 = workbook.createCellStyle();
HSSFFont font4 = workbook.createFont();
font4.setFontName("宋体");
font4.setFontHeightInPoints((short) 12);
cs4.setFont(font4);
cs4.setAlignment(HSSFCellStyle.ALIGN_CENTER);// 水平居中
cs4.setBorderBottom(HSSFCellStyle.BORDER_THIN);// 下边框
cs4.setBorderLeft(HSSFCellStyle.BORDER_THIN);// 左边框
cs4.setBorderRight(HSSFCellStyle.BORDER_THIN);// 右边框
cs4.setBorderTop(HSSFCellStyle.BORDER_THIN);// 上边框
HSSFCellStyle dateCellStyle=workbook.createCellStyle();
short defor=workbook.createDataFormat().getFormat("yyyy-mm-dd");
cs4.setDataFormat(defor);
//==========================设置字体样式end==========================
//设置列宽
sheet.setColumnWidth((short) 0, (short) (35.7*48));//n为列高的像素数
sheet.setColumnWidth((short) 1, (short) (35.7*100));
sheet.setColumnWidth((short) 2, (short) (35.7*120));
sheet.setColumnWidth((short) 3, (short) (35.7*130));
sheet.setColumnWidth((short) 4, (short) (35.7*310));
sheet.setColumnWidth((short) 5, (short) (35.7*100));
sheet.setColumnWidth((short) 6, (short) (35.7*80));
sheet.setColumnWidth((short) 7, (short) (35.7*150));
// 打印设置
HSSFPrintSetup hps = sheet.getPrintSetup();
hps.setPaperSize((short) 9); // 设置A4纸
// hps.setLandscape(true); // 将页面设置为横向打印模式
sheet.setHorizontallyCenter(true); // 设置打印页面为水平居中
sheet.setVerticallyCenter(true); // 设置打印页面为垂直居中
//wb.setPrintArea(0, "$A$2:$e$" + rowNum + 2);// 打印区域设置.
int rowNum = 0;// 行标
// int colNum = 0;// 列标
// 建立表头信息
// 在索引0的位置创建行(最顶端的行)
//第一行,表格标题
HSSFRow row0 = sheet.createRow((short) 0);
HSSFCell cell_0 = row0.createCell((short) 0);
cell_0.setCellType(HSSFCell.CELL_TYPE_STRING);
cell_0.setEncoding(HSSFCell.ENCODING_UTF_16);
cell_0.setCellStyle(cs);
cell_0.setCellValue("请示登记单");
sheet.addMergedRegion(new Region(0,(short)0,0,(short)7)); //合并单元格
row0.setHeightInPoints((float)22);//设置行高
//第二行 列标题
HSSFRow row = sheet.createRow((short) 1);
row.setHeightInPoints((float)22);//设置行高
// 单元格
// 在当前行的colNum列上创建单元格
HSSFCell cell_1 = row.createCell((short) 0);
// 定义单元格为字符类型,也可以指定为日期类型、数字类型
cell_1.setCellType(HSSFCell.CELL_TYPE_STRING);
// 定义编码方式,为了支持中文,这里使用了ENCODING_UTF_16
cell_1.setEncoding(HSSFCell.ENCODING_UTF_16);
// 为单元格设置格式
cell_1.setCellStyle(cs2);
// 添加内容至单元格
cell_1.setCellValue("序号");
HSSFCell cell1 = row.createCell((short) 1);
cell1.setCellType(HSSFCell.CELL_TYPE_STRING);
cell1.setEncoding(HSSFCell.ENCODING_UTF_16);
cell1.setCellStyle(cs2);
cell1.setCellValue("文件序号");
HSSFCell cell2 = row.createCell((short) 2);
cell2.setCellType(HSSFCell.CELL_TYPE_STRING);
cell2.setEncoding(HSSFCell.ENCODING_UTF_16);
cell2.setCellStyle(cs2);
cell2.setCellValue("文件编号");
HSSFCell cell3 = row.createCell((short) 3);
cell3.setCellType(HSSFCell.CELL_TYPE_STRING);
cell3.setEncoding(HSSFCell.ENCODING_UTF_16);
cell3.setCellStyle(cs2);
cell3.setCellValue("日期");
HSSFCell cell4 = row.createCell((short) 4);
cell4.setCellType(HSSFCell.CELL_TYPE_STRING);
cell4.setEncoding(HSSFCell.ENCODING_UTF_16);
cell4.setCellStyle(cs2);
cell4.setCellValue("标题");
HSSFCell cell5 = row.createCell((short) 5);
cell5.setCellType(HSSFCell.CELL_TYPE_STRING);
cell5.setEncoding(HSSFCell.ENCODING_UTF_16);
cell5.setCellStyle(cs2);
cell5.setCellValue("拟稿部门");
HSSFCell cell6 = row.createCell((short) 6);
cell6.setCellType(HSSFCell.CELL_TYPE_STRING);
cell6.setEncoding(HSSFCell.ENCODING_UTF_16);
cell6.setCellStyle(cs2);
cell6.setCellValue("拟稿人");
HSSFCell cell7 = row.createCell((short) 7);
cell7.setCellType(HSSFCell.CELL_TYPE_STRING);
cell7.setEncoding(HSSFCell.ENCODING_UTF_16);
cell7.setCellStyle(cs2);
cell7.setCellValue("备注");
long size = rs.getRecordCount();
System.out.println("==========>" + size);
HSSFCell data_cell0 = null;
HSSFCell data_cell1 = null;
HSSFCell data_cell2 = null;
HSSFCell data_cell3 = null;
HSSFCell data_cell4 = null;
HSSFCell data_cell5 = null;
HSSFCell data_cell6 = null;
HSSFCell data_cell7 = null;
for (int i = 0; i < size; i++) {
// 新建第rowNum行
row = sheet.createRow((short) i + 2);//从第三行开始
row.setHeightInPoints((float)22);//设置行高
data_cell0 = row.createCell((short) 0);
data_cell0.setEncoding(HSSFCell.ENCODING_UTF_16);
data_cell0.setCellStyle(cs3);
data_cell0.setCellValue(i+1);
//文件序号
data_cell1 = row.createCell((short) 1);
data_cell1.setEncoding(HSSFCell.ENCODING_UTF_16);
data_cell1.setCellStyle(cs3);
data_cell1.setCellValue(rs.getString("WJNumber"));
//文件编号
data_cell2 = row.createCell((short) 2);
data_cell2.setEncoding(HSSFCell.ENCODING_UTF_16);
data_cell2.setCellStyle(cs3);
data_cell2.setCellValue(rs.getString("Fd_No"));
//日期
data_cell3 = row.createCell((short) 3);
data_cell3.setEncoding(HSSFCell.ENCODING_UTF_16);
data_cell3.setCellStyle(cs3);
String tempDate = rs.getString("QSDate");
if(tempDate.length()>10){
tempDate= tempDate.replaceAll(" 00:00:00","");
}
tempDate = tempDate.replaceAll("\\.","-");
data_cell3.setCellValue(tempDate);
//标题
data_cell4 = row.createCell((short) 4);
data_cell4.setEncoding(HSSFCell.ENCODING_UTF_16);
data_cell4.setCellStyle(cs3);
data_cell4.setCellValue(rs.getString("fldSubject"));
//拟稿部门
data_cell5 = row.createCell((short) 5);
data_cell5.setEncoding(HSSFCell.ENCODING_UTF_16);
data_cell5.setCellStyle(cs3);
data_cell5.setCellValue(rs.getString("fd_planDept"));
//拟稿人
data_cell6 = row.createCell((short) 6);
data_cell6.setEncoding(HSSFCell.ENCODING_UTF_16);
data_cell6.setCellStyle(cs3);
data_cell6.setCellValue(rs.getString("seJbMan"));
//备注
data_cell7 = row.createCell((short) 7);
data_cell7.setEncoding(HSSFCell.ENCODING_UTF_16);
data_cell7.setCellStyle(cs3);
data_cell7.setCellValue(rs.getString("Fd_Remark"));
}
//response.setCharacterEncoding("gbk");
response.setContentType("application/octet-stream");
response.setHeader("Content-Disposition", "attachment;filename=_Report.xls");
workbook.write(response.getOutputStream());
response.getOutputStream().flush();
response.getOutputStream().close();
}catch(Exception e){
e.printStackTrace();
}
}
}
%>
分享到:
相关推荐
一、JSP导出Excel 1. **准备库**:在JSP中导出Excel,通常会用到Apache POI库。这是一个用于读写Microsoft Office格式文件的Java库,包括Excel。首先,需要将POI库添加到项目依赖中。 2. **创建Excel工作簿**:...
在JSP页面导出Excel时,我们会用到POI库来创建和操作Excel工作簿、工作表和单元格。首先,确保项目中已经引入了Apache POI的相关依赖。 2. **服务器端代码** 在后端Java代码中,你需要创建一个Servlet或者...
总结,JSP导出Excel涉及到数据处理、文件流操作、Excel格式设置等多个方面,理解并掌握这些知识点,能有效解决实际项目中的问题,提升用户体验。在实践过程中,不断学习和优化代码,可以使得导出功能更加高效、稳定...
总之,JSP导出Excel和Word是常见的功能需求,通过Apache POI库可以轻松实现。正确设置响应头和使用流处理可以确保文件能被正确下载,同时根据实际需求调整数据处理和样式设置,能够创建符合业务需求的导出文件。
#### 结合JSP导出Excel 在Web应用中,通常会结合JSP页面来动态生成Excel文件并提供下载。这涉及到设置正确的HTTP响应头,以便浏览器识别文件类型和进行下载。例如,在JSP中可以这样设置: ```jsp *,javax.servlet....
**二、导出Excel到JSP** 1. **创建Excel文件**:在服务器端,使用Apache POI创建一个新的工作簿对象,然后添加工作表。根据需要设置标题行和其他格式。 2. **填充数据**:从数据库或其他数据源获取数据,使用POI ...
在IT行业中,尤其是在Web开发领域,常常需要将网页上的数据导出为Excel格式,以便用户进行下载和进一步处理。本文将详细介绍如何使用JSP(JavaServer Pages)来实现这一功能,特别是针对页面上的HTML表格数据。 ...
本人试过了可以用,做jsp程序导出excel功能的可以参考下,下载后按照模版进行修改
关于jsp导出excel用javascript实现
查询数据跳转到当前的jsp,通过获取后台的接口数据导出excel文件,最后再自动跳转到上一个的页面。
jsp导出身份证到excel时候格式不对但以X结尾的却可以.docx
"jsp页面数据通过excel导出"这个主题就是关于如何在Java Web应用程序中利用JSP(JavaServer Pages)技术和Apache POI库将动态生成的数据导出为Excel文件。Apache POI是一个强大的API,它允许开发者读写Microsoft ...
**JSP Struts2 分页 导出Excel** 在Web开发中,经常需要处理大量数据,这时分页显示和导出功能就显得尤为重要。JSP(JavaServer Pages)和Struts2作为Java Web开发中的常见技术,可以帮助我们构建动态、交互的网页...
在IT行业中,尤其是在...总结来说,JSP导出Excel并保持数字格式的关键在于创建和应用自定义的单元格样式,避免Excel自动转换为科学计数法。通过Apache POI库,我们可以灵活地控制Excel文件的生成,满足各种格式需求。
描述部分进一步明确了文章的目的——不仅仅是在JSP页面上显示数据,更重要的是能够将这些数据导出成Excel格式,方便用户在客户端进行进一步的操作,如数据分析、打印等。这里强调的是“快速生成报表”,意味着介绍的...
### JSP导出Excel并支持分Sheet导出的方法详解 #### 概述 在Web开发领域,特别是使用Java Server Pages (JSP)进行后端处理的应用程序中,经常需要将数据库中的数据导出到Excel文件中供用户下载或进一步处理。这种...
Excel 文件的 library,它非常小巧而且易用,能够用一个 Excel 模板加上数据来渲染产生最终的 Excel 文件,比直接用 POI 这种底层的 API 来写要方便很多,尤其对于那些需要严格控制格式的 Excel 报表有非常大的帮助...
总结来说,"JSP SERVLET 导出数据库内容到EXCEL"是一个典型的Java Web应用场景,结合了JSP的视图呈现、Servlet的业务处理和数据库操作,以及第三方库Apache POI的文件生成能力,为企业级应用提供了强大的数据导出...
在IT领域,特别是Web开发中,JSP(JavaServer Pages)...在JSP中导入导出Excel文件,Apache POI是一个强大且灵活的工具。掌握其基本用法后,可以高效地处理各种Excel文件相关的任务,从而提升Web应用的数据处理能力。
本项目以"jsp实现excel上传至数据库,以及从数据库导出excel"为主题,提供了一种实用的方法,适合初学者学习。下面将详细解释这个过程涉及的关键技术点。 1. JSP(JavaServer Pages):JSP是一种动态网页技术,允许...