利用Java控制EXCEL實(shí)例詳解發(fā)布者:本站 時(shí)間:2020-05-06 15:05:43
使用Windows操作系統(tǒng)的朋友對(duì)Excel(電子表格)一定不會(huì)陌生,但是要使用Java語(yǔ)言來(lái)操縱Excel文件并不是一件容易的事。在Web應(yīng)用日益盛行的今天,通過(guò)Web來(lái)操作Excel文件的需求越來(lái)越強(qiáng)烈,目前較為流行的操作是在JSP或Servlet 中創(chuàng)建一個(gè)CSV (comma separated values)文件,并將這個(gè)文件以MIME,text/csv類(lèi)型返回給瀏覽器,接著瀏覽器調(diào)用Excel并且顯示CSV文件。這樣只是說(shuō)可以訪問(wèn)到Excel文件,但是還不能真正的操縱Excel文件,本文將給大家一個(gè)驚喜,向大家介紹一個(gè)開(kāi)放源碼項(xiàng)目 Java Excel API,使用它大家就可以方便地操縱Excel文件了。
JAVA EXCEL API簡(jiǎn)介
Java Excel是一開(kāi)放源碼項(xiàng)目,通過(guò)它Java開(kāi)發(fā)人員可以讀取Excel文件的內(nèi)容、創(chuàng)建新的Excel文件、更新已經(jīng)存在的Excel文件。使用該API非Windows操作系統(tǒng)也可以通過(guò)純Java應(yīng)用來(lái)處理Excel數(shù)據(jù)表。因?yàn)槭鞘褂肑ava編寫(xiě)的,所以我們?cè)赪eb應(yīng)用中可以通過(guò)JSP、Servlet來(lái)調(diào)用API實(shí)現(xiàn)對(duì)Excel數(shù)據(jù)表的訪問(wèn)。 現(xiàn)在發(fā)布的穩(wěn)定版本是V2.0,提供以下功能:
·從Excel 95、97、2000等格式的文件中讀取數(shù)據(jù);
·讀取Excel公式(可以讀取Excel 97以后的公式);
·生成Excel數(shù)據(jù)表(格式為Excel 97);
·支持字體、數(shù)字、日期的格式化;
·支持單元格的陰影操作,以及顏色操作;
·修改已經(jīng)存在的數(shù)據(jù)表;
· 現(xiàn)在還不支持以下功能,但不久就會(huì)提供了:
·不能夠讀取圖表信息;
可以讀,但是不能生成公式,任何類(lèi)型公式最后的計(jì)算值都可以讀出;
應(yīng)用示例
從Excel文件讀取數(shù)據(jù)表
Java Excel API既可以從本地文件系統(tǒng)的一個(gè)文件(.xls),也可以從輸入流中讀取Excel數(shù)據(jù)表。讀取Excel數(shù)據(jù)表的第一步是創(chuàng)建Workbook(術(shù)語(yǔ):工作薄),下面的代碼片段舉例說(shuō)明了應(yīng)該如何操作:(完整代碼見(jiàn)ExcelReading.java)
import java.io.*;
import jxl.*;
… … … …
try
{
//構(gòu)建Workbook對(duì)象, 只讀Workbook對(duì)象
//直接從本地文件創(chuàng)建Workbook
//從輸入流創(chuàng)建Workbook
InputStream is = new FileInputStream(sourcefile);
jxl.Workbook rwb = Workbook.getWorkbook(is);
}
catch (Exception e)
{
e.printStackTrace();
}
一旦創(chuàng)建了Workbook,我們就可以通過(guò)它來(lái)訪問(wèn)Excel Sheet(術(shù)語(yǔ):工作表)。參考下面的代碼片段:
//獲取第一張Sheet表
Sheet rs = rwb.getSheet(0);
我們既可能通過(guò)Sheet的名稱來(lái)訪問(wèn)它,也可以通過(guò)下標(biāo)來(lái)訪問(wèn)它。如果通過(guò)下標(biāo)來(lái)訪問(wèn)的話,要注意的一點(diǎn)是下標(biāo)從0開(kāi)始,就像數(shù)組一樣。
一旦得到了Sheet,我們就可以通過(guò)它來(lái)訪問(wèn)Excel Cell(術(shù)語(yǔ):?jiǎn)卧?。參考下面的代碼片段:
//獲取第一行,第一列的值
Cell c00 = rs.getCell(0, 0);
String strc00 = c00.getContents();
//獲取第一行,第二列的值
Cell c10 = rs.getCell(1, 0);
String strc10 = c10.getContents();
//獲取第二行,第二列的值
Cell c11 = rs.getCell(1, 1);
String strc11 = c11.getContents();
System.out.println("Cell(0, 0)" + " value : " + strc00 + "; type : " +
c00.getType());
System.out.println("Cell(1, 0)" + " value : " + strc10 + "; type : " +
c10.getType());
System.out.println("Cell(1, 1)" + " value : " + strc11 + "; type : " +
c11.getType());
如果僅僅是取得Cell的值,我們可以方便地通過(guò)getContents()方法,它可以將任何類(lèi)型的Cell值都作為一個(gè)字符串返回。示例代碼中Cell(0, 0)是文本型,Cell(1, 0)是數(shù)字型,Cell(1,1)是日期型,通過(guò)getContents(),三種類(lèi)型的返回值都是字符型。
如果有需要知道Cell內(nèi)容的確切類(lèi)型,API也提供了一系列的方法。參考下面的代碼片段:
String strc00 = null;
double strc10 = 0.00;
Date strc11 = null;
Cell c00 = rs.getCell(0, 0);
Cell c10 = rs.getCell(1, 0);
Cell c11 = rs.getCell(1, 1);
if(c00.getType() == CellType.LABEL)
{
LabelCell labelc00 = (LabelCell)c00;
strc00 = labelc00.getString();
}
if(c10.getType() == CellType.NUMBER)
{
NmberCell numc10 = (NumberCell)c10;
strc10 = numc10.getValue();
}
if(c11.getType() == CellType.DATE)
{
DateCell datec11 = (DateCell)c11;
strc11 = datec11.getDate();
}
System.out.println("Cell(0, 0)" + " value : " + strc00 + "; type : " +
c00.getType());
System.out.println("Cell(1, 0)" + " value : " + strc10 + "; type : " +
c10.getType());
System.out.println("Cell(1, 1)" + " value : " + strc11 + "; type : " +
c11.getType());
在得到Cell對(duì)象后,通過(guò)getType()方法可以獲得該單元格的類(lèi)型,然后與API提供的基本類(lèi)型相匹配,強(qiáng)制轉(zhuǎn)換成相應(yīng)的類(lèi)型,最后調(diào)用相應(yīng)的取值方法getXXX(),就可以得到確定類(lèi)型的值。API提供了以下基本類(lèi)型,與Excel的數(shù)據(jù)格式相對(duì)應(yīng)。
每種類(lèi)型的具體意義,請(qǐng)參見(jiàn)Java Excel API Document。
當(dāng)你完成對(duì)Excel電子表格數(shù)據(jù)的處理后,一定要使用close()方法來(lái)關(guān)閉先前創(chuàng)建的對(duì)象,以釋放讀取數(shù)據(jù)表的過(guò)程中所占用的內(nèi)存空間,在讀取大量數(shù)據(jù)時(shí)顯得尤為重要。參考如下代碼片段:
//操作完成時(shí),關(guān)閉對(duì)象,釋放占用的內(nèi)存空間
rwb.close();
Java Excel API提供了許多訪問(wèn)Excel數(shù)據(jù)表的方法,在這里我只簡(jiǎn)要地介紹幾個(gè)常用的方法,其它的方法請(qǐng)參考附錄中的Java Excel API Document。
選擇我們,優(yōu)質(zhì)服務(wù),不容錯(cuò)過(guò)
1. 優(yōu)秀的網(wǎng)絡(luò)資源,強(qiáng)大的網(wǎng)站優(yōu)化技術(shù),穩(wěn)定的網(wǎng)站和速度保證
2. 15年上海網(wǎng)站建設(shè)經(jīng)驗(yàn),優(yōu)秀的技術(shù)和設(shè)計(jì)水平,更放心
3. 全程省心服務(wù),不必?fù)?dān)心自己不懂網(wǎng)絡(luò),更省心。
------------------------------------------------------------
24小時(shí)聯(lián)系電話:021-58370032