- 浏览: 3012223 次
- 性别:
- 来自: 河南
文章分类
- 全部博客 (340)
- Java综合 (26)
- 程序人生 (53)
- RIA-ExtJS专栏 (18)
- RIA-mxGraph专栏 (4)
- RIA-Flex4专栏 (43)
- 框架-Spring专栏 (16)
- 框架-持久化专栏 (22)
- 框架-Struts2专栏 (11)
- 框架-Struts专栏 (12)
- SQL/NOSQL (12)
- 报表/图表 (2)
- 工作流 (5)
- XML专栏 (4)
- 日常报错解决方案 (5)
- Web前端-综合 (12)
- Web/JSP (14)
- Web前端-ajax专栏 (14)
- Web前端-JQuery专栏 (9)
- IDE技巧 (6)
- FILE/IO (14)
- 远程服务调用 (2)
- SSO单点登录 (2)
- 资源分享 (22)
- 云计算 (1)
- 项目管理 (3)
- php专栏 (1)
- Python专栏 (2)
- Linux (1)
- 缓存系统 (1)
- 队列服务器 (1)
- 网络编程 (0)
- Node.js (1)
最新评论
-
hui1989106a:
我的也不能解压,360和好压都试了,都不行
《Spring in Action》完整中文版分享下载 -
temotemo:
这些example有些过时了,官方建议使用HBase-1.0 ...
Java操作Hbase进行建表、删表以及对数据进行增删改查,条件查询 -
zy8102:
非常感谢~
HeadFirst系列之七:《深入浅出SQL》原版高清PDF电子书分享下载 -
zy8102:
重命名了一下搞定了
HeadFirst系列之七:《深入浅出SQL》原版高清PDF电子书分享下载 -
zy8102:
为什么下载以后老解压不了呢?
HeadFirst系列之七:《深入浅出SQL》原版高清PDF电子书分享下载
首先引用网上的文章,谈谈JXL与POI的区别
POI为apache公司的一个子项目,主要是提供一组操作windows文档的Java API.
Java Excel俗称jxl是一开放源码项目,通过它Java开发人员可以读取Excel文件的内容、创建新的Excel文件、更新已经存在的Excel文件。使用该API非Windows操作系统也可以通过纯Java应用来处理Excel数据表。因为是使用Java编写的,所以我们在Web应用中可以通过JSP、Servlet来调用API实现对Excel数据表的访问。
就这两者的区别,主要谈下JVM虚拟机内存消耗的情况.
数据量3000条数据,每条60列.JVM虚拟机内存大小64M.
使用POI:运行到2800条左右就报内存溢出.
使用JXL:3000条全部出来,并且内存还有21M的空间.
可想而知,在对内存的消耗方面差距还是挺大的.
也许是由于JXL在对资源回收利用方面做的还挺不错的.
关于两者效率方面,没有研究过,我想这个也是基于大数据量而言的,数据量小的话基本上差别不大,也不难被发觉.但是大的数据量,POI消耗的JVM内存远比JXL消耗的多.但相比提供的功能的话,JXL又相对弱了点.所以如果要实现的功能比较复杂的情况下可以考虑使用POI,但如果只想生成一些大数据量可以考虑使用JXL,或者CSV也是一个不错的选择,不过CSV并不是真正的excel.
这里单独介绍JXL对EXCEL的操作
import jxl.*;
import jxl.format.Underlinestyle;
import jxl.write.*;
import jxl.write.Number;
import jxl.write.Boolean;
import java.io.*;
public class ExcelHandle
{
public ExcelHandle()
{
}
/**
* 读取Excel
*
* @param filePath
*/
public static void readExcel(String filePath)
{
try
{
InputStream is = new FileInputStream(filePath);
Workbook rwb = Workbook.getWorkbook(is);
//Sheet st = rwb.getSheet("0")这里有两种方法获取sheet表,1为名字,2为下标,从0开始
Sheet st = rwb.getSheet("original");
Cell c00 = st.getCell(0,0);
//通用的获取cell值的方式,返回字符串
String strc00 = c00.getContents();
//获得cell具体类型值的方式
if(c00.getType() == CellType.LABEL)
{
LabelCell labelc00 = (LabelCell)c00;
strc00 = labelc00.getString();
}
//输出
System.out.println(strc00);
//关闭
rwb.close();
}
catch(Exception e)
{
e.printStackTrace();
}
}
/**
* 输出Excel
*
* @param os
*/
public static void writeExcel(OutputStream os)
{
try
{
/**
* 只能通过API提供的工厂方法来创建Workbook,而不能使用WritableWorkbook的构造函数,
* 因为类WritableWorkbook的构造函数为protected类型
* method(1)直接从目标文件中读取WritableWorkbook wwb = Workbook.createWorkbook(new File(targetfile));
* method(2)如下实例所示 将WritableWorkbook直接写入到输出流
*/
WritableWorkbook wwb = Workbook.createWorkbook(os);
//创建Excel工作表 指定名称和位置
WritableSheet ws = wwb.createSheet("Test Sheet 1",0);
//**************往工作表中添加数据*****************
//1.添加Label对象
Label label = new Label(0,0,"this is a label test");
ws.addCell(label);
//添加带有字型formatting对象
WritableFont wf = new WritableFont(WritableFont.TIMES,18,WritableFont.BOLD,true);
WritableCellformat wcf = new WritableCellformat(wf);
Label labelcf = new Label(1,0,"this is a label test",wcf);
ws.addCell(labelcf);
//添加带有字体颜色的formatting对象
WritableFont wfc = new WritableFont(WritableFont.ARIAL,10,WritableFont.NO_BOLD,false,
Underlinestyle.NO_UNDERLINE,jxl.format.Colour.RED);
WritableCellformat wcfFC = new WritableCellformat(wfc);
Label labelCF = new Label(1,0,"This is a Label Cell",wcfFC);
ws.addCell(labelCF);
//2.添加Number对象
Number labelN = new Number(0,1,3.1415926);
ws.addCell(labelN);
//添加带有formatting的Number对象
Numberformat nf = new Numberformat("#.##");
WritableCellformat wcfN = new WritableCellformat(nf);
Number labelNF = new jxl.write.Number(1,1,3.1415926,wcfN);
ws.addCell(labelNF);
//3.添加Boolean对象
Boolean labelB = new jxl.write.Boolean(0,2,false);
ws.addCell(labelB);
//4.添加DateTime对象
jxl.write.DateTime labelDT = new jxl.write.DateTime(0,3,new java.util.Date());
ws.addCell(labelDT);
//添加带有formatting的Dateformat对象
Dateformat df = new Dateformat("dd MM yyyy hh:mm:ss");
WritableCellformat wcfDF = new WritableCellformat(df);
DateTime labelDTF = new DateTime(1,3,new java.util.Date(),wcfDF);
ws.addCell(labelDTF);
//添加图片对象,jxl只支持png格式图片
File image = new File("f:\\2.png");
WritableImage wimage = new WritableImage(0,1,2,2,image);
ws.addImage(wimage);
//写入工作表
wwb.write();
wwb.close();
}
catch(Exception e)
{
e.printStackTrace();
}
}
/**
* 拷贝后,进行修改,其中file1为被copy对象,file2为修改后创建的对象;如果不想改名字的话他们可以一样
* 尽单元格原有的格式化修饰是不能去掉的,我们还是可以将新的单元格修饰加上去,
* 以使单元格的内容以不同的形式表现
* @param file1
* @param file2
*/
public static void modifyExcel(File file1,File file2)
{
try
{
Workbook rwb = Workbook.getWorkbook(file1);
//打开一个文件的副本,并且指定数据写回到原文件
WritableWorkbook wwb = Workbook.createWorkbook(file2,rwb);//copy
WritableSheet ws = wwb.getSheet(0);
WritableCell wc = ws.getWritableCell(0,0);
//判断单元格的类型,做出相应的转换
if(wc.getType == CellType.LABEL)
{
Label label = (Label)wc;
label.setString("The value has been modified");
}
wwb.write();
wwb.close();
rwb.close();
}
catch(Exception e)
{
e.printStackTrace();
}
}
//测试
public static void main(String[] args)
{
try
{
//读Excel
ExcelHandle.readExcel("f:/testRead.xls");
//输出Excel
File fileWrite = new File("f:/testWrite.xls");
fileWrite.createNewFile();
OutputStream os = new FileOutputStream(fileWrite);
ExcelHandle.writeExcel(os);
//修改Excel
ExcelHandle.modifyExcel(new file(""),new File(""));
}
catch(Exception e)
{
e.printStackTrace();
}
}
}
2.在jsp中做相关测试,创建一个writeExcel.jsp
<%
response.reset();//清除Buffer
response.setContentType("application/vnd.ms-excel");
File fileWrite = new File("f:/testWrite.xls");
fileWrite.createNewFile();
new FileOutputStream(fileWrite);
ExcelHandle.writeExcel(new FileOutputStream(fileWrite));
%>
在IE中浏览writeExcel.jsp就可以动态生成Excel文档了,其中response.setContentType("application/vnd.ms-excel");语句必须要,才能确保不乱码,在jsp中输入<%@page contentType="application/vnd.ms-excel;charset=GBK"%>不行。
比如测试一个:
public static void modifyExcel(File file1,File file2)
{
WritableWorkbook workbook=null;
WritableSheet sheet=null;
Workbook rwb;
try {
rwb = Workbook.getWorkbook(file1);
workbook = Workbook.createWorkbook(file2,rwb);
sheet=workbook.getSheet(0);
Label label=new Label(2,2,"zzzz");
sheet.addCell(label);
workbook.write();
workbook.close();
} catch (BiffException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (RowsExceededException e) {
e.printStackTrace();
} catch (WriteException e) {
e.printStackTrace();
}
}
MAIN方法中调用
modifyExcel(new File("D:/NewExcelDir/aaa.xls"),new File("D:/NewExcelDir/aaa.xls"));
执行就可以看到进行了修改
评论
2 楼
贝塔ZQ
2017-02-14
读写以及修改excel文件,试试用pageoffice吧。
1 楼
xutao5641745
2011-07-21
楼主,求解决,,,,jxl在读取17M的文件时报内存溢出。。。。。
下面我贴出我的代码 :
这两种方式 ,我都试了,,,都抛内存溢出异常
我的环境: jdk1.5 eclipse3.4内存分配是:
-startup
plugins/org.eclipse.equinox.launcher_1.1.0.v20100507.jar
--launcher.library
plugins/org.eclipse.equinox.launcher.win32.win32.x86_1.1.1.R36x_v20100810
-product
org.eclipse.epp.package.jee.product
--launcher.defaultAction
openFile
--launcher.XXMaxPermSize
256M
-showsplash
org.eclipse.platform
--launcher.XXMaxPermSize
256m
--launcher.defaultAction
openFile
-vmargs
-Dosgi.requiredJavaVersion=1.5
-Xms40m
-Xmx512m
我觉得这样的内存应该不会出现读取17M的文件而溢出吧。。。。。。。[/color][color=black]
下面我贴出我的代码 :
long time = System.currentTimeMillis(); try { //拿到excel文件 Workbook book = Workbook.getWorkbook(new File(Glob.jxlFilePath)); //拿到所有工作表对象 Sheet[] sheetArray = book.getSheets(); int sheetCount = sheetArray.length; for(int i=0;i<sheetCount;i++){ Sheet sheet = sheetArray[i]; // ********************方式一:通过数组方式取,缺点:占内存大;优点:数据精确度高**************** //拿到第1列的所有数据 Cell[] cells1 = sheet.getColumn(0); //拿到第2列的所有数据 Cell[] cells2 = sheet.getColumn(1); //拿到第2列的所有数据 Cell[] cells3 = sheet.getColumn(2); //拿到第2列的所有数据 Cell[] cells4 = sheet.getColumn(3); //拿到第2列的所有数据 Cell[] cells5 = sheet.getColumn(4); //拿到第2列的所有数据 Cell[] cells6 = sheet.getColumn(5); for(int j=0;j<cells1.length;j++){ System.out.println("cells1:"+cells1[j].getContents()+" cells2:"+cells2[j].getContents()+" cells3:"+cells3[j].getContents()+" cells4:"+cells4[j].getContents()+" cells5:"+cells5[j].getContents()+" cells6:"+cells6[j].getContents()); } System.out.println("i:"+i); // **********************方式二:占内存小;数据精确度低*************** // //拿到总行数 // int length = sheet.getRows(); // // for(int j=0;j<sheet.getRows();j++){ // // Cell cell1 = sheet.getCell(0, j); // // Cell cell2 = sheet.getCell(1, j); // // Cell cell3 = sheet.getCell(2,j); // // Cell cell4 = sheet.getCell(3,j); // // Cell cell5 = sheet.getCell(4,j); // // Cell cell6 = sheet.getCell(5,j); // // System.out.println("cell1:"+cell1.getContents()+" cell2:"+cell2.getContents()+" cell3:"+cell3.getContents()+" cell4:"+cell4.getContents()+" cell5:"+cell5.getContents()+" cell6:"+cell6.getContents()); // // } // System.out.println(length+" i:"+i); sheet=null; } book.close(); } catch (Exception e) { System.out.println(e); System.out.println(System.currentTimeMillis()-time); } System.out.println(System.currentTimeMillis()- time);
这两种方式 ,我都试了,,,都抛内存溢出异常
我的环境: jdk1.5 eclipse3.4内存分配是:
-startup
plugins/org.eclipse.equinox.launcher_1.1.0.v20100507.jar
--launcher.library
plugins/org.eclipse.equinox.launcher.win32.win32.x86_1.1.1.R36x_v20100810
-product
org.eclipse.epp.package.jee.product
--launcher.defaultAction
openFile
--launcher.XXMaxPermSize
256M
-showsplash
org.eclipse.platform
--launcher.XXMaxPermSize
256m
--launcher.defaultAction
openFile
-vmargs
-Dosgi.requiredJavaVersion=1.5
-Xms40m
-Xmx512m
我觉得这样的内存应该不会出现读取17M的文件而溢出吧。。。。。。。[/color][color=black]
发表评论
-
POI设置EXCEL单元格格式为文本、小数、百分比、货币、日期、科学计数法和中文大写
2011-01-25 11:07 79545再读本篇文章之前,请先看我的前一篇文章,前一篇文章中有重点讲到 ... -
POI对EXCEL的操作【重点:如何设置CELL格式为文本格式】
2011-01-25 10:07 80941实际开发过程中通常用到的就是从数据库导出EXCEL表格了,JX ... -
web网页上的文件下载功能
2010-11-18 16:00 12502首先提供下我的下载页面 那么要实现这么一种下载的话,t ... -
在IIS中设置默认的FTP目录
2010-10-19 10:13 2616【实现目标】 IIS的FTP目录默认是在“C:\inetpub ... -
Apache Common-Configuration的使用,重点介绍对XML和Properties的读取操作
2010-09-25 15:41 10019Apache Common-Configuration工具可以 ... -
JAVA开发中POI和JXL区分
2010-07-27 10:48 7525java操作excel表格,以前只知道POI。POI是apac ... -
Java开发过程中文件上传的各种方式全面总结
2010-07-07 17:54 10037到目前为止:我接触到的有关上传的类型有这么几种JSP+Ser ... -
FTP远程上传下载文件
2010-05-25 22:21 5203最近工作中用到FTP知识,感觉比较好用,代码贴在下面 /* ... -
Java实现将Excel批量转换成txt
2010-05-24 06:24 6816有博友发信说要Excel转txt不成,这是因为没有准确的设置, ... -
CSV文件读取与生成以及Excel文件的读取生成
2010-05-23 17:28 10692其一:CSV文件读取与生成 ①CSV文件读取 ... -
Java IO流各种使用方式总结
2010-05-23 17:04 2823①针对普通文本的复 ... -
使用JAVA(iText)生成word(rtf)文档---内容可含图片哦
2010-03-24 15:58 22580当我使用这个JAVA生成RTF文件时费了好大的劲,原本是 ... -
lucene开发中有关读取pdf,html,word,rtf,txt,powerpoint,excel等文档的操作
2010-03-23 10:18 7589关于这七种文档,我相信应该是最常用的文档了 在以下的介绍中 ...
相关推荐
Java中的JXL库是一个广泛使用的库,用于读取和写入Microsoft Excel文件。这个库使得在Java应用程序中处理Excel数据变得简单,而无需依赖于Microsoft Office。以下是对JXL库在进行Excel读写操作时的一些关键知识点的...
本文将详细介绍如何使用jxl库进行Excel文件的读写操作,以及适合初学者的关键知识点。 ### 1. jxl库介绍 jxl库是一个Java库,它提供了API来读取、修改和创建Excel工作簿。jxl支持Excel 97-2003格式(.xls),但不...
Java Excel API(简称JXL)是一个广泛使用的开源库,它允许Java开发者轻松地读取、写入和修改Microsoft Excel文件。在"JXL读写Excel例子demo"中,我们将探讨如何利用JXL库来处理Excel数据。这个示例程序包含了一个名...
JXL库提供了方便的API,使得开发者可以轻松地处理Excel数据,包括读取单元格内容、修改工作表、添加公式,以及本文重点讨论的——插入和输出图片。 **一、JXL库介绍** JXL是一个开源的Java库,专门用于处理Excel...
本文将深入探讨Java编程语言中如何使用Apache POI库和JExcelAPI(JXL)来读取、写入及操作Excel文件,同时也包括设置列宽以及处理合并或拆分的单元格内容。 首先,Apache POI是Apache软件基金会的一个开源项目,专...
JXL是一个轻量级的Java库,它提供了丰富的API来读取、写入和修改Excel文件(.xls格式)。由于JXL不依赖于Microsoft Office或任何其他外部组件,因此它可以在没有Excel安装的环境中工作。 2. **安装与导入** 首先...
在Java编程环境中,JXL库是一个非常实用的工具,它允许开发者轻松地读取、写入和修改Excel文件。标题“jxl操作excel文件例子”指的是利用JXL库进行Excel文件处理的实际应用。描述中提到的“通过jxl操作excel,简单...
首先,让我们关注`jxl.jar`库,它是一个广泛使用的Java库,允许开发者读取、写入和修改Excel文件。以下是如何使用jxl.jar来读取和写入Excel文件的基本步骤: 1. **读取Excel文件**: - 引入jxl.jar库到项目类路径...
JXL是Java Excel API的简称,它提供了一套完整的API,可以创建、修改和读取Excel文件。这个库支持多种Excel特性,包括单元格格式、公式、图表、图像等。Jxl.jar文件包含了JXL库的所有类和方法,将其添加到Java项目的...
JXL库是一个Java库,专门用于读写Microsoft Excel文件。它允许程序以编程方式创建、修改和读取Excel工作簿。JXL支持多种操作,如创建新工作表、添加单元格数据、设置单元格格式、合并单元格、读取数据等。例如,你...
而JXL库则是一个专门用于Java平台的Excel文件读写工具,它允许开发者以编程方式来处理Excel文件,包括创建、读取、修改和保存Excel工作簿。本文将围绕“浅谈jxl解析excel ——复制、修改excel表”这一主题,深入探讨...
标题中的“JXL”指的是Java Excel Library,这是一个用于在Java应用程序中读取、写入和修改Excel文件的开源库。这个库提供了丰富的API,使得开发者能够方便地处理Excel数据,而无需依赖Microsoft Office套件。 在...
Java中的JXL库是一个流行的第三方工具包,专门用于读写Microsoft Excel文件。它提供了一种简单的方式来处理Excel数据,使得开发者无需直接与低级API交互,就能方便地完成各种操作,如创建、读取和修改Excel工作簿和...
这篇博客“JXL 下载 Excel 文档”可能是介绍如何使用JXL库在Java程序中创建、读取或修改Excel文件。 描述中提到的链接指向了一个ITEYE博客文章,虽然具体内容没有给出,但我们可以推测博主可能详细介绍了使用JXL库...
总结来说,jxl.jar库是Java操作Excel的一个实用工具,它提供了丰富的API来读取、修改和创建Excel文件。通过熟练掌握这个库,开发者可以方便地在Java应用程序中集成Excel相关的功能,进行数据处理和报告生成等工作。...
jxl库正是解决这一问题的关键,它允许Java程序创建、读取和修改Excel文件,极大地拓展了Java在数据处理上的能力。 jxl库是由JExcelAPI项目提供的,它是一个开源的Java库,专门用于处理Microsoft Excel文件。在本文...
Java中的JXL库是一个非常实用的工具,它允许开发者在应用程序中读取、写入和修改Excel文件。这个库特别适合那些需要处理大量数据并希望将数据格式化为表格的项目。下面我们将深入探讨JXL库在Java Excel解析中的应用...
3. **JXL库**:JXL库提供了广泛的API,支持读取、写入、修改Excel文件。它可以创建新的工作簿,添加工作表,读取单元格的数据,设置单元格的样式,以及处理公式等。在本压缩包中,`jxl`目录下可能包含了JXL库的jar...
JXL是一个开源库,允许Java开发者读取、写入以及修改Microsoft Excel文件。在Excel中,合并单元格是一项常见的操作,用于创建标题或者格式化表格。 在描述中提到的“jxl读写该Excel例子合并单元格”,意味着我们将...