- 浏览: 2990122 次
- 性别:
- 来自: 河南
文章分类
- 全部博客 (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 79224再读本篇文章之前,请先看我的前一篇文章,前一篇文章中有重点讲到 ... -
POI对EXCEL的操作【重点:如何设置CELL格式为文本格式】
2011-01-25 10:07 80670实际开发过程中通常用到的就是从数据库导出EXCEL表格了,JX ... -
web网页上的文件下载功能
2010-11-18 16:00 12410首先提供下我的下载页面 那么要实现这么一种下载的话,t ... -
在IIS中设置默认的FTP目录
2010-10-19 10:13 2570【实现目标】 IIS的FTP目录默认是在“C:\inetpub ... -
Apache Common-Configuration的使用,重点介绍对XML和Properties的读取操作
2010-09-25 15:41 9948Apache Common-Configuration工具可以 ... -
JAVA开发中POI和JXL区分
2010-07-27 10:48 7392java操作excel表格,以前只知道POI。POI是apac ... -
Java开发过程中文件上传的各种方式全面总结
2010-07-07 17:54 9977到目前为止:我接触到的有关上传的类型有这么几种JSP+Ser ... -
FTP远程上传下载文件
2010-05-25 22:21 5152最近工作中用到FTP知识,感觉比较好用,代码贴在下面 /* ... -
Java实现将Excel批量转换成txt
2010-05-24 06:24 6762有博友发信说要Excel转txt不成,这是因为没有准确的设置, ... -
CSV文件读取与生成以及Excel文件的读取生成
2010-05-23 17:28 10612其一:CSV文件读取与生成 ①CSV文件读取 ... -
Java IO流各种使用方式总结
2010-05-23 17:04 2774①针对普通文本的复 ... -
使用JAVA(iText)生成word(rtf)文档---内容可含图片哦
2010-03-24 15:58 22454当我使用这个JAVA生成RTF文件时费了好大的劲,原本是 ... -
lucene开发中有关读取pdf,html,word,rtf,txt,powerpoint,excel等文档的操作
2010-03-23 10:18 7483关于这七种文档,我相信应该是最常用的文档了 在以下的介绍中 ...
相关推荐
学习使用JXL读写EXCEL文件, 学习使用JXL读写EXCEL文件。
jxl的excel读写操作 java操作excel的读写。
JXL读写Excel源码,为什么写到android里,是因为自身在做安卓测试,顺便回顾了下,其实都是java写的。
简单的介绍了JXL读写Excel java excle api
jxl读写excel 可运行 java版 适合刚读写excel的朋友 有注释
用jxl读写excel数据,输出图片到excel
JXL(Java Excel API)是一个用来动态读写Excel文件的开源框架,利用它可以在任何支持Java的操作系统上动态读写Excel文件。
ExcelDemo_Excel导出_下载_POI读excel_JXL读写excel_java读写excel_列宽_读取合并或拆分单元格内容
jxlAPI 文档 api excel 读写Excel
jxl操作excel文件示例,对于jxl的使用给出一个简单的示例,帮助大家快速入门
JXL(Java操作Excel文件Oracle数据库)
Jxl读写Excel例子demo.jxl.jar是通过java操作excel表格的工具类库
使用jxl读和写Excel文件
利用jxl操作excel文件,提取exce文件数据生成txt文件。
使用jxl,读写excel数据进数据库的例子。 需要jxl.jar、poi-2.0-final-20040126.jar、mysql-connector-java-3.0.8-stable-bin.jar、jakarta-poi-1.5.1-final-20020615.jar。
常用java IO操作以及用jxl读写excel 工具源代码 此工具作用:把目录里面的文件旧的国际化key值换成新的国际化值。根据excel文件。
JXL操作EXCEL 数据库导出EXCEL相关文件一些详细资料
Java利用JXL读和写操作Excel表格示例代码,可直接导入MyEclipse使用
jxl的读Excel,写Excel,更新Excel以及一些文件操作
jxl读写excel常见操作搜集整理,jxl工具类