public static void main(String args[]) throws BiffException, IOException, WriteException{
//1 從Excel檔案讀取資料表
//Java Excel API既可以從本地檔案系統的一個檔案(.xls),也可以從輸入流中讀取Excel資料表。
//讀取Excel資料表的第一步是建立Workbook(術語:工作薄),下面的程式碼片段舉例說明了應該如何操作:
//(完整程式碼見ExcelReading.java)
try
{
//構建Workbook物件, 只讀Workbook物件
//直接從本地檔案建立Workbook
//從輸入流建立Workbook
InputStream is = new FileInputStream("D:/user.xls");
jxl.Workbook rwb = Workbook.getWorkbook(is);
//一旦建立了Workbook,我們就可以透過它來訪問Excel Sheet(術語:工作表)。參考下面的程式碼片段:
//獲取第一張Sheet表
Sheet rs = (Sheet) rwb.getSheet(0);
//我們既可能透過Sheet的名稱來訪問它,也可以透過下標來訪問它。如果透過下標來訪問的話,
//要注意的一點是下標從0開始,就像陣列一樣。
//一旦得到了Sheet,我們就可以透過它來訪問Excel Cell(術語:單元格)。參考下面的程式碼片段:
//獲取第一行,第一列的值
Cell c00 = ((jxl.Sheet) rs).getCell(0, 0);
String strc00 = c00.getContents();
//獲取第一行,第二列的值
Cell c10 = ((jxl.Sheet) rs).getCell(1, 0);
String strc10 = c10.getContents();
//獲取第二行,第二列的值
Cell c11 = ((jxl.Sheet) 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的值,我們可以方便地透過getContents()方法,
//它可以將任何型別的Cell值都作為一個字串返回。示例程式碼中Cell(0, 0)是文字型,
//Cell(1, 0)是數字型,Cell(1,1)是日期型,透過getContents(),三種類型的返回值都是字元型。
//如果有需要知道Cell內容的確切型別,API也提供了一系列的方法。參考下面的程式碼片段:
String strcc00 = null;
double strcc10 = 0.00;
Date strcc11 = null;
Cell cc00 = ((jxl.Sheet) rs).getCell(0, 0);
Cell cc10 = ((jxl.Sheet) rs).getCell(1, 0);
Cell cc11 = ((jxl.Sheet) rs).getCell(1, 1);
if(c00.getType() == CellType.LABEL)
LabelCell labelc00 = (LabelCell)cc00;
strcc00 = labelc00.getString();
}
if(c10.getType() == CellType.NUMBER)
NumberCell numc10 = (NumberCell)cc10;
strcc10 = numc10.getValue();
if(c11.getType() == CellType.DATE)
DateCell datec11 = (DateCell)cc11;
strcc11 = datec11.getDate();
System.out.println("Cell(0, 0)" + " value : " + strcc00 + "; type : " + cc00.getType());
System.out.println("Cell(1, 0)" + " value : " + strcc10 + "; type : " + cc10.getType());
System.out.println("Cell(1, 1)" + " value : " + strcc11 + "; type : " + cc11.getType());
//在得到Cell物件後,透過getType()方法可以獲得該單元格的型別,然後與API提供的基本型別相匹配,
//強制轉換成相應的型別,最後呼叫相應的取值方法getXXX(),就可以得到確定型別的值。
//API提供了以下基本型別,與Excel的資料格式相對應,如下圖所示:
//每種型別的具體意義,請參見Java Excel API Document。
//當你完成對Excel電子表格資料的處理後,一定要使用close()方法來關閉先前建立的物件,
//以釋放讀取資料表的過程中所佔用的記憶體空間,在讀取大量資料時顯得尤為重要。參考如下程式碼片段:
//操作完成時,關閉物件,釋放佔用的記憶體空間
rwb.close();
catch (Exception e)
e.printStackTrace();
//Java Excel API提供了許多訪問Excel資料表的方法,在這裡我只簡要地介紹幾個常用的方法,
//其它的方法請參考附錄中的Java Excel API Document。
//Workbook類提供的方法
//1. int getNumberOfSheets();
//獲得工作薄(Workbook)中工作表(Sheet)的個數,示例:
jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
int sheets = rwb.getNumberOfSheets();
//2. Sheet[] getSheets();
//返回工作薄(Workbook)中工作表(Sheet)物件陣列,示例:
jxl.Workbook rwb2 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
Sheet[] sheets2 = (Sheet[]) rwb2.getSheets();
//3. String getVersion();
//返回正在使用的API的版本號,好像是沒什麼太大的作用。
jxl.Workbook rwb3 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
String apiVersion = rwb3.getVersion();
//Sheet介面提供的方法
//1) String getName();
//獲取Sheet的名稱,示例:
jxl.Workbook rwb4 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
jxl.Sheet rs = rwb4.getSheet(0);
String sheetName = rs.getName();
//2) int getColumns()
//獲取Sheet表中所包含的總列數,示例:
jxl.Workbook rwb5 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
jxl.Sheet rs2 = rwb5.getSheet(0);
int rsColumns = rs2.getColumns();
//3) Cell[] getColumn(int column)
//獲取某一列的所有單元格,返回的是單元格物件陣列,示例:
jxl.Workbook rwb6 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
jxl.Sheet rs3 = rwb6.getSheet(0);
Cell[] cell = rs3.getColumn(0);
//4) int getRows()
//獲取Sheet表中所包含的總行數,示例:
jxl.Workbook rwb7 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
jxl.Sheet rs4 = rwb7.getSheet(0);
int rsRows = rs4.getRows();
//5) Cell[] getRow(int row)
//獲取某一行的所有單元格,返回的是單元格物件陣列,示例子:
jxl.Workbook rwb8 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
jxl.Sheet rs5 = rwb8.getSheet(0);
Cell[] cell5 = rs5.getRow(0);
//6) Cell getCell(int column, int row)
//獲取指定單元格的物件引用,需要注意的是它的兩個引數,第一個是列數,第二個是行數,
//這與通常的行、列組合有些不同。
jxl.Workbook rwb9 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
jxl.Sheet rs6 = rwb9.getSheet(0);
Cell cell6 = rs6.getCell(0, 0);
public static void main(String args[]) throws BiffException, IOException, WriteException{
//1 從Excel檔案讀取資料表
//Java Excel API既可以從本地檔案系統的一個檔案(.xls),也可以從輸入流中讀取Excel資料表。
//讀取Excel資料表的第一步是建立Workbook(術語:工作薄),下面的程式碼片段舉例說明了應該如何操作:
//(完整程式碼見ExcelReading.java)
try
{
//構建Workbook物件, 只讀Workbook物件
//直接從本地檔案建立Workbook
//從輸入流建立Workbook
InputStream is = new FileInputStream("D:/user.xls");
jxl.Workbook rwb = Workbook.getWorkbook(is);
//一旦建立了Workbook,我們就可以透過它來訪問Excel Sheet(術語:工作表)。參考下面的程式碼片段:
//獲取第一張Sheet表
Sheet rs = (Sheet) rwb.getSheet(0);
//我們既可能透過Sheet的名稱來訪問它,也可以透過下標來訪問它。如果透過下標來訪問的話,
//要注意的一點是下標從0開始,就像陣列一樣。
//一旦得到了Sheet,我們就可以透過它來訪問Excel Cell(術語:單元格)。參考下面的程式碼片段:
//獲取第一行,第一列的值
Cell c00 = ((jxl.Sheet) rs).getCell(0, 0);
String strc00 = c00.getContents();
//獲取第一行,第二列的值
Cell c10 = ((jxl.Sheet) rs).getCell(1, 0);
String strc10 = c10.getContents();
//獲取第二行,第二列的值
Cell c11 = ((jxl.Sheet) 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的值,我們可以方便地透過getContents()方法,
//它可以將任何型別的Cell值都作為一個字串返回。示例程式碼中Cell(0, 0)是文字型,
//Cell(1, 0)是數字型,Cell(1,1)是日期型,透過getContents(),三種類型的返回值都是字元型。
//如果有需要知道Cell內容的確切型別,API也提供了一系列的方法。參考下面的程式碼片段:
String strcc00 = null;
double strcc10 = 0.00;
Date strcc11 = null;
Cell cc00 = ((jxl.Sheet) rs).getCell(0, 0);
Cell cc10 = ((jxl.Sheet) rs).getCell(1, 0);
Cell cc11 = ((jxl.Sheet) rs).getCell(1, 1);
if(c00.getType() == CellType.LABEL)
{
LabelCell labelc00 = (LabelCell)cc00;
strcc00 = labelc00.getString();
}
if(c10.getType() == CellType.NUMBER)
{
NumberCell numc10 = (NumberCell)cc10;
strcc10 = numc10.getValue();
}
if(c11.getType() == CellType.DATE)
{
DateCell datec11 = (DateCell)cc11;
strcc11 = datec11.getDate();
}
System.out.println("Cell(0, 0)" + " value : " + strcc00 + "; type : " + cc00.getType());
System.out.println("Cell(1, 0)" + " value : " + strcc10 + "; type : " + cc10.getType());
System.out.println("Cell(1, 1)" + " value : " + strcc11 + "; type : " + cc11.getType());
//在得到Cell物件後,透過getType()方法可以獲得該單元格的型別,然後與API提供的基本型別相匹配,
//強制轉換成相應的型別,最後呼叫相應的取值方法getXXX(),就可以得到確定型別的值。
//API提供了以下基本型別,與Excel的資料格式相對應,如下圖所示:
//每種型別的具體意義,請參見Java Excel API Document。
//當你完成對Excel電子表格資料的處理後,一定要使用close()方法來關閉先前建立的物件,
//以釋放讀取資料表的過程中所佔用的記憶體空間,在讀取大量資料時顯得尤為重要。參考如下程式碼片段:
//操作完成時,關閉物件,釋放佔用的記憶體空間
rwb.close();
}
catch (Exception e)
{
e.printStackTrace();
}
//Java Excel API提供了許多訪問Excel資料表的方法,在這裡我只簡要地介紹幾個常用的方法,
//其它的方法請參考附錄中的Java Excel API Document。
//Workbook類提供的方法
//1. int getNumberOfSheets();
//獲得工作薄(Workbook)中工作表(Sheet)的個數,示例:
jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
int sheets = rwb.getNumberOfSheets();
//2. Sheet[] getSheets();
//返回工作薄(Workbook)中工作表(Sheet)物件陣列,示例:
jxl.Workbook rwb2 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
Sheet[] sheets2 = (Sheet[]) rwb2.getSheets();
//3. String getVersion();
//返回正在使用的API的版本號,好像是沒什麼太大的作用。
jxl.Workbook rwb3 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
String apiVersion = rwb3.getVersion();
//Sheet介面提供的方法
//1) String getName();
//獲取Sheet的名稱,示例:
jxl.Workbook rwb4 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
jxl.Sheet rs = rwb4.getSheet(0);
String sheetName = rs.getName();
//2) int getColumns()
//獲取Sheet表中所包含的總列數,示例:
jxl.Workbook rwb5 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
jxl.Sheet rs2 = rwb5.getSheet(0);
int rsColumns = rs2.getColumns();
//3) Cell[] getColumn(int column)
//獲取某一列的所有單元格,返回的是單元格物件陣列,示例:
jxl.Workbook rwb6 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
jxl.Sheet rs3 = rwb6.getSheet(0);
Cell[] cell = rs3.getColumn(0);
//4) int getRows()
//獲取Sheet表中所包含的總行數,示例:
jxl.Workbook rwb7 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
jxl.Sheet rs4 = rwb7.getSheet(0);
int rsRows = rs4.getRows();
//5) Cell[] getRow(int row)
//獲取某一行的所有單元格,返回的是單元格物件陣列,示例子:
jxl.Workbook rwb8 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
jxl.Sheet rs5 = rwb8.getSheet(0);
Cell[] cell5 = rs5.getRow(0);
//6) Cell getCell(int column, int row)
//獲取指定單元格的物件引用,需要注意的是它的兩個引數,第一個是列數,第二個是行數,
//這與通常的行、列組合有些不同。
jxl.Workbook rwb9 = jxl.Workbook.getWorkbook(new File("D:/user.xls"));
jxl.Sheet rs6 = rwb9.getSheet(0);
Cell cell6 = rs6.getCell(0, 0);