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