- 浏览: 168199 次
- 性别:
- 来自: 成都
-
文章分类
最新评论
-
sunjia44:
很不错的方法
JTable设置单元格不可编辑 -
atian25:
主要是html dom生成的太多了.4.x版本中grid得到了 ...
ExtJS中GridPanel一次性加载500条以上数据(不分页),性能超级差,有时导致浏览器卡死! -
aspnetdb:
遇到过同样的情况,纠结中。grid显示不只和行后关系和列的多少 ...
ExtJS中GridPanel一次性加载500条以上数据(不分页),性能超级差,有时导致浏览器卡死! -
beyondsphinx:
我用TABLE一次加载几百行浏览器也卡死啊,客户端电脑,浏览器 ...
ExtJS中GridPanel一次性加载500条以上数据(不分页),性能超级差,有时导致浏览器卡死! -
共产主义:
我也遇到这个问题。用buffergrid加载的时候,数据量一多 ...
ExtJS中GridPanel一次性加载500条以上数据(不分页),性能超级差,有时导致浏览器卡死!
package cn.hld.practise.excel;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.net.URLEncoder;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import jxl.Workbook;
import jxl.format.UnderlineStyle;
import jxl.write.WritableFont;
public class TestServletOperateExcel extends HttpServlet
{
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException
{
/*
StringBuffer sb = new StringBuffer() ;
sb.append("测试导出Excel用,现在这个地方只是用一个字符串来表示") ;
sb.append("可以用DisplayTag 或者 vba 或者 jlx 或者 POI来进行导出Excel") ;
exportExcel("thename", sb,request,response) ;
*/
// response.setHeader("Content-disposition","attachment; filename=" + new String(("员工信息表.xls").getBytes("gb2312"),"iso8859-1"));
// response.setDateHeader("Expires", 0);
// response.setContentType("application/vnd.ms-excel;charset=GBK");
//下面是生成Excel但是不提示下载的信息的
try
{
//构建Workbook对象, 只读Workbook对象
//Method 1:创建可写入的Excel工作薄
// jxl.write.WritableWorkbook wwb = Workbook.createWorkbook(new File("c:/testt.xls"));
//Method 2:将WritableWorkbook直接写入到输出流
OutputStream os = new FileOutputStream("c:/testt.xls");
//OutputStream os = response.getOutputStream() ;
jxl.write.WritableWorkbook wwb = Workbook.createWorkbook(os);
//创建Excel工作表
jxl.write.WritableSheet ws = wwb.createSheet("Test Sheet 1", 0);
//jxl.write.Label labelC = new jxl.write.Label(0, 0, "This is a Label cell");
// 1.添加Label对象
jxl.write.Label labelC = new jxl.write.Label(0, 0, "这是一个电子表格测试");
ws.addCell(labelC);
// 添加带有字型Formatting的对象
jxl.write.WritableFont wf = new jxl.write.WritableFont(WritableFont.TIMES, 18, WritableFont.BOLD, true);
jxl.write.WritableCellFormat wcfF = new jxl.write.WritableCellFormat(wf);
jxl.write.Label labelCF1 = new jxl.write.Label(1, 0, "This is a Label Cell", wcfF);
ws.addCell(labelCF1);
// 添加带有字体颜色Formatting的对象
jxl.write.WritableFont wfc = new jxl.write.WritableFont(WritableFont.ARIAL, 10, WritableFont.NO_BOLD, false,
UnderlineStyle.NO_UNDERLINE, jxl.format.Colour.RED);
jxl.write.WritableCellFormat wcfFC = new jxl.write.WritableCellFormat(wfc);
jxl.write.Label labelCFC2 = new jxl.write.Label(1, 0, "This is a Label Cell", wcfFC);
ws.addCell(labelCFC2);
// 2.添加Number对象
jxl.write.Number labelN = new jxl.write.Number(0, 1, 3.1415926);
ws.addCell(labelN);
// 添加带有formatting的Number对象
jxl.write.NumberFormat nf = new jxl.write.NumberFormat("#.##");
jxl.write.WritableCellFormat wcfN = new jxl.write.WritableCellFormat(nf);
jxl.write.Number labelNF3 = new jxl.write.Number(1, 1, 3.1415926, wcfN);
ws.addCell(labelNF3);
// 3.添加Boolean对象
jxl.write.Boolean labelB = new jxl.write.Boolean(0, 2, false);
ws.addCell(labelB);
// 4.添加DateTime对象
jxl.write.DateTime labelDT4 = new jxl.write.DateTime(0, 3, new java.util.Date());
ws.addCell(labelDT4);
// 添加带有formatting的DateFormat对象
jxl.write.DateFormat df = new jxl.write.DateFormat("dd MM yyyy hh:mm:ss");
jxl.write.WritableCellFormat wcfDF = new jxl.write.WritableCellFormat(df);
jxl.write.DateTime labelDTF5 = new jxl.write.DateTime(1, 3, new java.util.Date(), wcfDF);
ws.addCell(labelDTF5);
//写入Exel工作表
wwb.write();
//关闭Excel工作薄对象
wwb.close();
os.flush() ;
os.close() ;
//下面是提示下载Excel的具体操作
String displayFileName = "产品报表.xls" ;
String downLoadFilePath = "c:/testt.xls" ;
displayFileName = URLEncoder.encode(displayFileName,"UTF-8");
response.reset();
response.setContentType("application/x-msdownload");
response.addHeader("Content-Disposition","attachment;filename=" + displayFileName);
OutputStream output = response.getOutputStream();
FileInputStream fis = new FileInputStream(downLoadFilePath);
byte[] b = new byte[1024];
int i = 0;
while((i = fis.read(b)) > 0)
{
output.write(b, 0, i);
}
output.flush();
fis.close();
output.close();
}
catch (Exception e)
{
e.printStackTrace();
}
}
/**
* The doPost method of the servlet. <br>
*
* This method is called when a form has its tag value method equals to post.
*
* @param request the request send by the client to the server
* @param response the response send by the server to the client
* @throws ServletException if an error occurred
* @throws IOException if an error occurred
*/
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException
{
doGet(request,response) ;
}
public void exportExcel(String fileName,StringBuffer sb, HttpServletRequest request,
HttpServletResponse response) {
ServletOutputStream o = null;
if (null != sb) {
try {
if(fileName==""){
fileName="DefaultName";
}
String length = String.valueOf(sb.length());//长度
byte[] b = sb.toString().getBytes("GB2312");
String filename = new String((fileName+".xls").getBytes("GB2312"),
"iso-8859-1");
o = response.getOutputStream();
response.reset();
response.setContentType("APPLICATION/OCTET-STREAM");
response.setHeader("Content_Length", length);
if (request.getHeader("User-Agent").indexOf("MSIE 5.5") != -1) {
/** MS IE5.5 */
response.setHeader("Content-disposition", "filename=\""
+ filename + "\"");
} else {
/** 非MS IE5.5 */
response.setHeader("Content-disposition",
"attachment;filename=\"" + filename + "\"");
}
try {
o.write(b);
o.flush();
} catch (Exception e) {
response.setStatus(HttpServletResponse.SC_OK);
response.flushBuffer();
} finally {
o.close();
}
} catch (Exception e) {
System.err.println(e.getMessage());
}
}
}
}
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.OutputStream;
import java.net.URLEncoder;
import javax.servlet.ServletException;
import javax.servlet.ServletOutputStream;
import javax.servlet.http.HttpServlet;
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import jxl.Workbook;
import jxl.format.UnderlineStyle;
import jxl.write.WritableFont;
public class TestServletOperateExcel extends HttpServlet
{
public void doGet(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException
{
/*
StringBuffer sb = new StringBuffer() ;
sb.append("测试导出Excel用,现在这个地方只是用一个字符串来表示") ;
sb.append("可以用DisplayTag 或者 vba 或者 jlx 或者 POI来进行导出Excel") ;
exportExcel("thename", sb,request,response) ;
*/
// response.setHeader("Content-disposition","attachment; filename=" + new String(("员工信息表.xls").getBytes("gb2312"),"iso8859-1"));
// response.setDateHeader("Expires", 0);
// response.setContentType("application/vnd.ms-excel;charset=GBK");
//下面是生成Excel但是不提示下载的信息的
try
{
//构建Workbook对象, 只读Workbook对象
//Method 1:创建可写入的Excel工作薄
// jxl.write.WritableWorkbook wwb = Workbook.createWorkbook(new File("c:/testt.xls"));
//Method 2:将WritableWorkbook直接写入到输出流
OutputStream os = new FileOutputStream("c:/testt.xls");
//OutputStream os = response.getOutputStream() ;
jxl.write.WritableWorkbook wwb = Workbook.createWorkbook(os);
//创建Excel工作表
jxl.write.WritableSheet ws = wwb.createSheet("Test Sheet 1", 0);
//jxl.write.Label labelC = new jxl.write.Label(0, 0, "This is a Label cell");
// 1.添加Label对象
jxl.write.Label labelC = new jxl.write.Label(0, 0, "这是一个电子表格测试");
ws.addCell(labelC);
// 添加带有字型Formatting的对象
jxl.write.WritableFont wf = new jxl.write.WritableFont(WritableFont.TIMES, 18, WritableFont.BOLD, true);
jxl.write.WritableCellFormat wcfF = new jxl.write.WritableCellFormat(wf);
jxl.write.Label labelCF1 = new jxl.write.Label(1, 0, "This is a Label Cell", wcfF);
ws.addCell(labelCF1);
// 添加带有字体颜色Formatting的对象
jxl.write.WritableFont wfc = new jxl.write.WritableFont(WritableFont.ARIAL, 10, WritableFont.NO_BOLD, false,
UnderlineStyle.NO_UNDERLINE, jxl.format.Colour.RED);
jxl.write.WritableCellFormat wcfFC = new jxl.write.WritableCellFormat(wfc);
jxl.write.Label labelCFC2 = new jxl.write.Label(1, 0, "This is a Label Cell", wcfFC);
ws.addCell(labelCFC2);
// 2.添加Number对象
jxl.write.Number labelN = new jxl.write.Number(0, 1, 3.1415926);
ws.addCell(labelN);
// 添加带有formatting的Number对象
jxl.write.NumberFormat nf = new jxl.write.NumberFormat("#.##");
jxl.write.WritableCellFormat wcfN = new jxl.write.WritableCellFormat(nf);
jxl.write.Number labelNF3 = new jxl.write.Number(1, 1, 3.1415926, wcfN);
ws.addCell(labelNF3);
// 3.添加Boolean对象
jxl.write.Boolean labelB = new jxl.write.Boolean(0, 2, false);
ws.addCell(labelB);
// 4.添加DateTime对象
jxl.write.DateTime labelDT4 = new jxl.write.DateTime(0, 3, new java.util.Date());
ws.addCell(labelDT4);
// 添加带有formatting的DateFormat对象
jxl.write.DateFormat df = new jxl.write.DateFormat("dd MM yyyy hh:mm:ss");
jxl.write.WritableCellFormat wcfDF = new jxl.write.WritableCellFormat(df);
jxl.write.DateTime labelDTF5 = new jxl.write.DateTime(1, 3, new java.util.Date(), wcfDF);
ws.addCell(labelDTF5);
//写入Exel工作表
wwb.write();
//关闭Excel工作薄对象
wwb.close();
os.flush() ;
os.close() ;
//下面是提示下载Excel的具体操作
String displayFileName = "产品报表.xls" ;
String downLoadFilePath = "c:/testt.xls" ;
displayFileName = URLEncoder.encode(displayFileName,"UTF-8");
response.reset();
response.setContentType("application/x-msdownload");
response.addHeader("Content-Disposition","attachment;filename=" + displayFileName);
OutputStream output = response.getOutputStream();
FileInputStream fis = new FileInputStream(downLoadFilePath);
byte[] b = new byte[1024];
int i = 0;
while((i = fis.read(b)) > 0)
{
output.write(b, 0, i);
}
output.flush();
fis.close();
output.close();
}
catch (Exception e)
{
e.printStackTrace();
}
}
/**
* The doPost method of the servlet. <br>
*
* This method is called when a form has its tag value method equals to post.
*
* @param request the request send by the client to the server
* @param response the response send by the server to the client
* @throws ServletException if an error occurred
* @throws IOException if an error occurred
*/
public void doPost(HttpServletRequest request, HttpServletResponse response)
throws ServletException, IOException
{
doGet(request,response) ;
}
public void exportExcel(String fileName,StringBuffer sb, HttpServletRequest request,
HttpServletResponse response) {
ServletOutputStream o = null;
if (null != sb) {
try {
if(fileName==""){
fileName="DefaultName";
}
String length = String.valueOf(sb.length());//长度
byte[] b = sb.toString().getBytes("GB2312");
String filename = new String((fileName+".xls").getBytes("GB2312"),
"iso-8859-1");
o = response.getOutputStream();
response.reset();
response.setContentType("APPLICATION/OCTET-STREAM");
response.setHeader("Content_Length", length);
if (request.getHeader("User-Agent").indexOf("MSIE 5.5") != -1) {
/** MS IE5.5 */
response.setHeader("Content-disposition", "filename=\""
+ filename + "\"");
} else {
/** 非MS IE5.5 */
response.setHeader("Content-disposition",
"attachment;filename=\"" + filename + "\"");
}
try {
o.write(b);
o.flush();
} catch (Exception e) {
response.setStatus(HttpServletResponse.SC_OK);
response.flushBuffer();
} finally {
o.close();
}
} catch (Exception e) {
System.err.println(e.getMessage());
}
}
}
}
发表评论
-
两分钟让你明白什么是ERP
2010-07-03 17:01 882把专业的问题通俗化—— ERP(Enterpris ... -
使用Java将Word转为Html或txt等
2010-04-29 11:01 1240前一段时间为这个问题头疼的不得了,后来查阅了资料终于解决了;现 ... -
如何利用Java-JACOB操作WORD文档
2010-04-29 10:50 1759JACOB是一个 JAVA到微软的 ... -
Ant教程详解
2010-04-22 09:06 879Ant是一个Apache基金会下的跨平台的构件工具,它可以实现 ... -
java调用.dll文件
2010-04-19 10:45 1541一.在程序用jnative调用window的dll 1. ... -
如何在Web页面上直接打开、编辑、创建Office文档
2010-04-18 15:03 1559如何在Web页面上做到像S ... -
Apache POI For Java Excel
2010-04-18 14:14 1530Apache POI For Java Excel POI的 ... -
Java 串口通信环境的配置
2010-03-19 11:03 2322做串口通信,要从网上下载三个文件:分别是: 1.COMM.J ... -
多浏览器兼容的CSS js 的 tab 选项卡
2010-03-14 14:18 1767<!DOCTYPE html PUBLIC " ... -
简单实用的CSS网页布局中文排版心得
2010-03-14 10:05 873一、如何设定文字字体、颜色、大小 — 使用font f ... -
CSS网页布局编码小技巧整理
2010-03-14 09:59 6711、ul标签在Mozilla中默认是有padding值的,而 ... -
Java编程中中文乱码的问题
2010-03-14 09:45 796http://blog.csdn.net/wonder4/ar ... -
Java操作手机发送短信
2010-03-14 09:09 1444作者:曹祺 Blog: http://bl ... -
一个非常有用工具软件
2010-03-14 08:23 834这个小工具非常有用,它可以将数据库表中的字段生成对应的Java ... -
JDK1.5中的打印服务
2010-03-14 08:18 994package com.unutrip.print; imp ... -
使用SUN的MAIL包发邮件
2010-03-11 09:02 1072import java.util.Properties; i ... -
java代码写excel和文本文档的导入导出【转】
2010-02-01 10:09 1694例子1-----》利用jxl包来完成excel导入导出 JX ... -
jxl生成excel
2010-02-01 10:06 848package campaign; import com.s ... -
利用jxl包生成Excel实例
2010-02-01 10:04 1342import jxl.*; import jxl.write. ... -
Tomcat tomcat-users.xml 配置用户
2010-01-31 16:11 1415<?xml version='1.0' encoding ...
相关推荐
这篇博客文章结合了这两个技术,展示了如何在Struts2应用中生成Excel文件并将其导出给用户下载。 在Java开发中,导出数据到Excel是常见的需求,特别是在处理大量结构化数据时,如报表或数据分析。JXL库提供了一个...
总结来说,Java利用JXL库生成Excel文件是通过创建工作簿、工作表、单元格,并设置它们的属性和内容来实现的。JXL提供了广泛的API来处理各种复杂的Excel操作,是Java环境下生成Excel文件的一个实用工具。
"jxl模版生成excel" 指的是使用JExcelAPI(简称jxl)这个Java库来创建基于模板的Excel文件。JExcelAPI是一个开源项目,允许程序开发者读写Microsoft Excel文件,它支持从Java数据结构直接导出到Excel格式,同时也可...
使用jxl生成excel的通用方法,参数List<?>数据,LinkedHashMap,String>实体类属性名和中文列名的键值对
本资源提供了一个利用jxl库实现Java程序中生成Excel表格的解决方案。jxl是一个广泛使用的开源Java库,它允许开发者读取、写入和修改Microsoft Excel文件。 首先,我们来详细了解一下jxl库。jxl库支持多种Excel操作...
在Java编程环境中,生成Excel报表是一项常见的任务,尤其在数据处理和数据分析中。Apache POI 和 JExcelAPI(JXL)是两个广泛使用的库,分别用于处理Microsoft Office的POI格式(包括Excel)和Java环境中的Excel文件...
自己封装的方法,调用 XlHelper.getXl(List<?> voList , Object head , OutputStream ops)方法,直接返回需要的excel,而不需要再去写jxl的方法。第一个参数voList 是excel里的内容,第二个参数head是excel表头。第...
jxl是对excel强有力的操纵工具,它具有丰富的API可以满足对excel的各种开发需要。
用jxl生成EXCEL表格,一个非常简单易懂的写法。
这篇博客“利用Jxl生成excel文件”提供了关于如何使用Jxl库创建Excel文档的指导。 首先,Jxl库允许开发者在Java程序中直接操作Excel格式的数据,而无需依赖Microsoft Office套件。它支持多种Excel功能,如单元格...
1. **创建新Excel文档**:通过JXL,你可以创建一个新的Excel工作簿,并添加工作表,设置单元格的样式、颜色、字体等。 2. **读取Excel文档**:可以打开已存在的Excel文件,读取其中的数据,包括文本、数字、日期、...
例子如下: Object是一个对象实体类,如Studnet.java. List 是一个对象集合,后面的是输出路径. WriteExcel rw=new WriteExcel(); rw.writeExcel(new Object(), List, "f:/a.xls","库存表");
Excel下载涉及从服务器生成Excel文件并提供给客户端下载。主要步骤如下: 1. 根据需要从数据库或其他数据源获取数据。 2. 使用JXL的`Workbook.createWorkbook()`方法创建一个新的工作簿对象。 3. 创建一个`Sheet`...
上述代码中,`doGet`方法创建了一个Servlet,当用户访问特定URL时,Servlet会生成一个Excel文件并作为HTTP响应的一部分返回,浏览器通常会提示用户下载。 值得注意的是,JXL库只支持Excel 97-2003格式(.xls),...
这篇博客“使用JXL生成Excel实例详解”将深入探讨如何利用JXL库来创建Excel文件。 首先,要开始使用JXL,你需要在项目中添加JXL的依赖。如果你使用的是Maven,可以在pom.xml文件中添加以下依赖: ```xml ...
相比之下,Jxl生成的标准Excel文件在样式和功能方面更为可靠,因为大多数用户都熟悉Excel的界面和功能。此外,Jxl的API直观易用,对于需要快速实现打印功能的开发者来说是一个不错的选择。 总的来说,Jxl库为Java...
在IT行业中,生成Excel报表是常见的数据展示和分析任务,而JXL库为Java开发者提供了一个强大且便捷的解决方案。JXL,全称Java Excel API,是一个开源的Java库,专为读取、写入以及修改Excel文件设计。它允许程序员在...
在Web开发中,Jxl库提供了一种方便的方式来生成标准的Excel文件,可以替代JavaScript的打印或封闭式套打插件。由于Excel具有丰富的内置功能和样式,因此能满足大多数用户的需求。Jxl库易于上手,特别适合那些对打印...
Java通过JXL库生成Excel文档是一项常见的任务,尤其在数据导出、报表生成等领域非常实用。JXL是一个Java API,允许我们读写Microsoft Excel文件,而无需依赖Microsoft Office。在这个过程中,我们可以创建新的工作簿...
在IT行业中,处理和操作Excel数据是一项常见的任务,特别是在数据导入导出、分析和报告生成等领域。JXL是一个Java库,专门用于读取、写入和修改Excel文件,它为Java开发者提供了一种方便的方式来处理Excel数据,而...