- 浏览: 107183 次
- 性别:
- 来自: 北京
文章分类
最新评论
-
wxynxyo:
非常感谢,解决了一个问题
Spring MVC 类型转换 @InitBinder使用 转 -
hxsmile:
很清晰明了
MyEclipse下XFire开发Webservice实例 -
yaoyy:
...
MyEclipse下XFire开发Webservice实例 -
hyl523:
好,明白了,多谢!
MyEclipse下XFire开发Webservice实例
JXL 读写以及修改EXCEL文件
首先引用网上的文章,谈谈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的操作
- <SPANstyle="FONT-SIZE:medium">importjxl.*;
- importjxl.format.Underlinestyle;
- importjxl.write.*;
- importjxl.write.Number;
- importjxl.write.Boolean;
- importjava.io.*;
- publicclassExcelHandle
- {
- publicExcelHandle()
- {
- }
- /**
- *读取Excel
- *
- *@paramfilePath
- */
- publicstaticvoidreadExcel(StringfilePath)
- {
- try
- {
- InputStreamis=newFileInputStream(filePath);
- Workbookrwb=Workbook.getWorkbook(is);
- //Sheetst=rwb.getSheet("0")这里有两种方法获取sheet表,1为名字,2为下标,从0开始
- Sheetst=rwb.getSheet("original");
- Cellc00=st.getCell(0,0);
- //通用的获取cell值的方式,返回字符串
- Stringstrc00=c00.getContents();
- //获得cell具体类型值的方式
- if(c00.getType()==CellType.LABEL)
- {
- LabelCelllabelc00=(LabelCell)c00;
- strc00=labelc00.getString();
- }
- //输出
- System.out.println(strc00);
- //关闭
- rwb.close();
- }
- catch(Exceptione)
- {
- e.printStackTrace();
- }
- }
- /**
- *输出Excel
- *
- *@paramos
- */
- publicstaticvoidwriteExcel(OutputStreamos)
- {
- try
- {
- /**
- *只能通过API提供的工厂方法来创建Workbook,而不能使用WritableWorkbook的构造函数,
- *因为类WritableWorkbook的构造函数为protected类型
- *method(1)直接从目标文件中读取WritableWorkbookwwb=Workbook.createWorkbook(newFile(targetfile));
- *method(2)如下实例所示将WritableWorkbook直接写入到输出流
- */
- WritableWorkbookwwb=Workbook.createWorkbook(os);
- //创建Excel工作表指定名称和位置
- WritableSheetws=wwb.createSheet("TestSheet1",0);
- //**************往工作表中添加数据*****************
- //1.添加Label对象
- Labellabel=newLabel(0,0,"thisisalabeltest");
- ws.addCell(label);
- //添加带有字型formatting对象
- WritableFontwf=newWritableFont(WritableFont.TIMES,18,WritableFont.BOLD,true);
- WritableCellformatwcf=newWritableCellformat(wf);
- Labellabelcf=newLabel(1,0,"thisisalabeltest",wcf);
- ws.addCell(labelcf);
- //添加带有字体颜色的formatting对象
- WritableFontwfc=newWritableFont(WritableFont.ARIAL,10,WritableFont.NO_BOLD,false,
- Underlinestyle.NO_UNDERLINE,jxl.format.Colour.RED);
- WritableCellformatwcfFC=newWritableCellformat(wfc);
- LabellabelCF=newLabel(1,0,"ThisisaLabelCell",wcfFC);
- ws.addCell(labelCF);
- //2.添加Number对象
- NumberlabelN=newNumber(0,1,3.1415926);
- ws.addCell(labelN);
- //添加带有formatting的Number对象
- Numberformatnf=newNumberformat("#.##");
- WritableCellformatwcfN=newWritableCellformat(nf);
- NumberlabelNF=newjxl.write.Number(1,1,3.1415926,wcfN);
- ws.addCell(labelNF);
- //3.添加Boolean对象
- BooleanlabelB=newjxl.write.Boolean(0,2,false);
- ws.addCell(labelB);
- //4.添加DateTime对象
- jxl.write.DateTimelabelDT=newjxl.write.DateTime(0,3,newjava.util.Date());
- ws.addCell(labelDT);
- //添加带有formatting的Dateformat对象
- Dateformatdf=newDateformat("ddMMyyyyhh:mm:ss");
- WritableCellformatwcfDF=newWritableCellformat(df);
- DateTimelabelDTF=newDateTime(1,3,newjava.util.Date(),wcfDF);
- ws.addCell(labelDTF);
- //添加图片对象,jxl只支持png格式图片
- Fileimage=newFile("f:\\2.png");
- WritableImagewimage=newWritableImage(0,1,2,2,image);
- ws.addImage(wimage);
- //写入工作表
- wwb.write();
- wwb.close();
- }
- catch(Exceptione)
- {
- e.printStackTrace();
- }
- }
- /**
- *拷贝后,进行修改,其中file1为被copy对象,file2为修改后创建的对象;如果不想改名字的话他们可以一样
- *尽单元格原有的格式化修饰是不能去掉的,我们还是可以将新的单元格修饰加上去,
- *以使单元格的内容以不同的形式表现
- *@paramfile1
- *@paramfile2
- */
- publicstaticvoidmodifyExcel(Filefile1,Filefile2)
- {
- try
- {
- Workbookrwb=Workbook.getWorkbook(file1);
- //打开一个文件的副本,并且指定数据写回到原文件
- WritableWorkbookwwb=Workbook.createWorkbook(file2,rwb);//copy
- WritableSheetws=wwb.getSheet(0);
- WritableCellwc=ws.getWritableCell(0,0);
- //判断单元格的类型,做出相应的转换
- if(wc.getType==CellType.LABEL)
- {
- Labellabel=(Label)wc;
- label.setString("Thevaluehasbeenmodified");
- }
- wwb.write();
- wwb.close();
- rwb.close();
- }
- catch(Exceptione)
- {
- e.printStackTrace();
- }
- }
- //测试
- publicstaticvoidmain(String[]args)
- {
- try
- {
- //读Excel
- ExcelHandle.readExcel("f:/testRead.xls");
- //输出Excel
- FilefileWrite=newFile("f:/testWrite.xls");
- fileWrite.createNewFile();
- OutputStreamos=newFileOutputStream(fileWrite);
- ExcelHandle.writeExcel(os);
- //修改Excel
- ExcelHandle.modifyExcel(newfile(""),newFile(""));
- }
- catch(Exceptione)
- {
- e.printStackTrace();
- }
- }
- }
- 2.在jsp中做相关测试,创建一个writeExcel.jsp
- <%
- response.reset();//清除Buffer
- response.setContentType("application/vnd.ms-excel");
- FilefileWrite=newFile("f:/testWrite.xls");
- fileWrite.createNewFile();
- newFileOutputStream(fileWrite);
- ExcelHandle.writeExcel(newFileOutputStream(fileWrite));
- %>
- 在IE中浏览writeExcel.jsp就可以动态生成Excel文档了,其中response.setContentType("application/vnd.ms-excel");语句必须要,才能确保不乱码,在jsp中输入<%@pagecontentType="application/vnd.ms-excel;charset=GBK"%>不行。</SPAN>
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"%>不行。
比如测试一个:
- <SPANstyle="FONT-SIZE:medium">publicstaticvoidmodifyExcel(Filefile1,Filefile2)
- {
- WritableWorkbookworkbook=null;
- WritableSheetsheet=null;
- Workbookrwb;
- try{
- rwb=Workbook.getWorkbook(file1);
- workbook=Workbook.createWorkbook(file2,rwb);
- sheet=workbook.getSheet(0);
- Labellabel=newLabel(2,2,"zzzz");
- sheet.addCell(label);
- workbook.write();
- workbook.close();
- }catch(BiffExceptione){
- e.printStackTrace();
- }catch(IOExceptione){
- e.printStackTrace();
- }catch(RowsExceededExceptione){
- e.printStackTrace();
- }catch(WriteExceptione){
- e.printStackTrace();
- }
- }</SPAN>
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"));
执行就可以看到进行了修改
相关推荐
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库,专门用于读写Microsoft Excel文件。它允许程序以编程方式创建、修改和读取Excel工作簿。JXL支持多种操作,如创建新工作表、添加单元格数据、设置单元格格式、合并单元格、读取数据等。例如,你...
标题中的“JXL”指的是Java Excel Library,这是一个用于在Java应用程序中读取、写入和修改Excel文件的开源库。这个库提供了丰富的API,使得开发者能够方便地处理Excel数据,而无需依赖Microsoft Office套件。 在...
而JXL库则是一个专门用于Java平台的Excel文件读写工具,它允许开发者以编程方式来处理Excel文件,包括创建、读取、修改和保存Excel工作簿。本文将围绕“浅谈jxl解析excel ——复制、修改excel表”这一主题,深入探讨...
Java中的JXL库是一个流行的第三方工具包,专门用于读写Microsoft Excel文件。它提供了一种简单的方式来处理Excel数据,使得开发者无需直接与低级API交互,就能方便地完成各种操作,如创建、读取和修改Excel工作簿和...
这篇博客“JXL 下载 Excel 文档”可能是介绍如何使用JXL库在Java程序中创建、读取或修改Excel文件。 描述中提到的链接指向了一个ITEYE博客文章,虽然具体内容没有给出,但我们可以推测博主可能详细介绍了使用JXL库...
总结来说,jxl.jar库是Java操作Excel的一个实用工具,它提供了丰富的API来读取、修改和创建Excel文件。通过熟练掌握这个库,开发者可以方便地在Java应用程序中集成Excel相关的功能,进行数据处理和报告生成等工作。...
JXL是一个开源库,允许Java开发者读取、写入以及修改Microsoft Excel文件。在Excel中,合并单元格是一项常见的操作,用于创建标题或者格式化表格。 在描述中提到的“jxl读写该Excel例子合并单元格”,意味着我们将...
jxl库正是解决这一问题的关键,它允许Java程序创建、读取和修改Excel文件,极大地拓展了Java在数据处理上的能力。 jxl库是由JExcelAPI项目提供的,它是一个开源的Java库,专门用于处理Microsoft Excel文件。在本文...
JXL是一个广泛使用的Java库,它允许开发者方便地读写Excel文件,而无需依赖Microsoft Office。 标题中的“用jxl实现java对Excel表格的增删改查”指的是使用JXL库来完成对Excel文件的基本操作:增加数据(Add)、...
Java中的JXL库是一个非常实用的工具,它允许开发者在应用程序中读取、写入和修改Excel文件。这个库特别适合那些需要处理大量数据并希望将数据格式化为表格的项目。下面我们将深入探讨JXL库在Java Excel解析中的应用...
JExcelAPI,简称为jxl,是一个用Java编写的开源库,它允许开发者在Java应用程序中读取、写入和修改Microsoft Excel文件。这个库非常实用,特别是在处理大量数据导入导出、报表生成等场景下。jxl库支持多种Excel功能...
它支持读取、写入以及修改Excel 97-2004(.xls)格式的文件。虽然不支持最新的.xlsx格式(这需要使用如Apache POI等其他库),但对于处理旧版Excel文件,JXL是一个简单且实用的选择。 要通过JXL使用模板导出Excel,...