`
javaDevil
  • 浏览: 36483 次
  • 性别: Icon_minigender_1
  • 来自: 深圳
社区版块
存档分类
最新评论

jsp导出excel之格式控制

    博客分类:
  • jsp
阅读更多

   在做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和pdf格式

    一、JSP导出Excel 1. **准备库**:在JSP中导出Excel,通常会用到Apache POI库。这是一个用于读写Microsoft Office格式文件的Java库,包括Excel。首先,需要将POI库添加到项目依赖中。 2. **创建Excel工作簿**:...

    jsp页面导出excel

    在JSP页面导出Excel时,我们会用到POI库来创建和操作Excel工作簿、工作表和单元格。首先,确保项目中已经引入了Apache POI的相关依赖。 2. **服务器端代码** 在后端Java代码中,你需要创建一个Servlet或者...

    jsp导出excel一般问题及汇总

    总结,JSP导出Excel涉及到数据处理、文件流操作、Excel格式设置等多个方面,理解并掌握这些知识点,能有效解决实际项目中的问题,提升用户体验。在实践过程中,不断学习和优化代码,可以使得导出功能更加高效、稳定...

    jsp导出Excel;简单实用!导出Excel;导出Word

    总之,JSP导出Excel和Word是常见的功能需求,通过Apache POI库可以轻松实现。正确设置响应头和使用流处理可以确保文件能被正确下载,同时根据实际需求调整数据处理和样式设置,能够创建符合业务需求的导出文件。

    java及jsp下导出excel表格

    #### 结合JSP导出Excel 在Web应用中,通常会结合JSP页面来动态生成Excel文件并提供下载。这涉及到设置正确的HTTP响应头,以便浏览器识别文件类型和进行下载。例如,在JSP中可以这样设置: ```jsp *,javax.servlet....

    jsp导入导出excel文件

    **二、导出Excel到JSP** 1. **创建Excel文件**:在服务器端,使用Apache POI创建一个新的工作簿对象,然后添加工作表。根据需要设置标题行和其他格式。 2. **填充数据**:从数据库或其他数据源获取数据,使用POI ...

    JSP页面导出EXCEL简单方法

    在IT行业中,尤其是在Web开发领域,常常需要将网页上的数据导出为Excel格式,以便用户进行下载和进一步处理。本文将详细介绍如何使用JSP(JavaServer Pages)来实现这一功能,特别是针对页面上的HTML表格数据。 ...

    jsp程序excel导出功能

    本人试过了可以用,做jsp程序导出excel功能的可以参考下,下载后按照模版进行修改

    关于jsp导出excel用javascript实现

    关于jsp导出excel用javascript实现

    导出excel的jsp开发

    查询数据跳转到当前的jsp,通过获取后台的接口数据导出excel文件,最后再自动跳转到上一个的页面。

    jsp导出身份证到excel时候格式不对但以X结尾的却可以.docx

    jsp导出身份证到excel时候格式不对但以X结尾的却可以.docx

    jsp页面数据通过excel导出

    "jsp页面数据通过excel导出"这个主题就是关于如何在Java Web应用程序中利用JSP(JavaServer Pages)技术和Apache POI库将动态生成的数据导出为Excel文件。Apache POI是一个强大的API,它允许开发者读写Microsoft ...

    JSP Struts2 分页 导出Excel

    **JSP Struts2 分页 导出Excel** 在Web开发中,经常需要处理大量数据,这时分页显示和导出功能就显得尤为重要。JSP(JavaServer Pages)和Struts2作为Java Web开发中的常见技术,可以帮助我们构建动态、交互的网页...

    JSP导出Excel,数字格式化成字符串

    在IT行业中,尤其是在...总结来说,JSP导出Excel并保持数字格式的关键在于创建和应用自定义的单元格样式,避免Excel自动转换为科学计数法。通过Apache POI库,我们可以灵活地控制Excel文件的生成,满足各种格式需求。

    导出jsp页面为excel文档

    描述部分进一步明确了文章的目的——不仅仅是在JSP页面上显示数据,更重要的是能够将这些数据导出成Excel格式,方便用户在客户端进行进一步的操作,如数据分析、打印等。这里强调的是“快速生成报表”,意味着介绍的...

    jsp导出excel并支持分sheet导出的方法.docx

    ### JSP导出Excel并支持分Sheet导出的方法详解 #### 概述 在Web开发领域,特别是使用Java Server Pages (JSP)进行后端处理的应用程序中,经常需要将数据库中的数据导出到Excel文件中供用户下载或进一步处理。这种...

    JSP运用模板导出Excel

    Excel 文件的 library,它非常小巧而且易用,能够用一个 Excel 模板加上数据来渲染产生最终的 Excel 文件,比直接用 POI 这种底层的 API 来写要方便很多,尤其对于那些需要严格控制格式的 Excel 报表有非常大的帮助...

    JSP SERVLET 导出数据库内容到EXCEL

    总结来说,"JSP SERVLET 导出数据库内容到EXCEL"是一个典型的Java Web应用场景,结合了JSP的视图呈现、Servlet的业务处理和数据库操作,以及第三方库Apache POI的文件生成能力,为企业级应用提供了强大的数据导出...

    JSP中导入导出Excel文件.

    在IT领域,特别是Web开发中,JSP(JavaServer Pages)...在JSP中导入导出Excel文件,Apache POI是一个强大且灵活的工具。掌握其基本用法后,可以高效地处理各种Excel文件相关的任务,从而提升Web应用的数据处理能力。

    jsp实现excel上传至数据库,以及 从数据库导出excel

    本项目以"jsp实现excel上传至数据库,以及从数据库导出excel"为主题,提供了一种实用的方法,适合初学者学习。下面将详细解释这个过程涉及的关键技术点。 1. JSP(JavaServer Pages):JSP是一种动态网页技术,允许...

Global site tag (gtag.js) - Google Analytics