使用該API非Windows作業系統也可以透過純Java應用程式來處理Excel資料表。因為是使用Java編寫的,所以我們在網頁應用程式中可以透過JSP、Servlet來呼叫API來實現對Excel資料表的存取。
複製代碼代碼如下:
package com.yonyou.test;
import java.io.File;
import java.io.IOException;
import jxl.Workbook;
import jxl.format.Alignment;
import jxl.format.Border;
import jxl.format.BorderLineStyle;
import jxl.format.Colour;
import jxl.format.UnderlineStyle;
import jxl.write.Label;
import jxl.write.NumberFormats;
import jxl.write.WritableCellFormat;
import jxl.write.WritableFont;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
import jxl.write.WriteException;
import jxl.write.biff.RowsExceededException;
public class JxlTable {
private final static JxlTable jxlTable = new JxlTable();
public static JxlTable getInstance() {
return jxlTable;
}
public JxlTable() {
}
public boolean createTable(String header, String[] body, String filePath) {
boolean createFlag = true;
WritableWorkbook book;
try {
// 根據路徑產生excel文件
book = Workbook.createWorkbook(new File(filePath));
// 建立一個sheet名為"表格"
WritableSheet sheet = book.createSheet("表格", 0);
// 設定NO列寬度
sheet.setColumnView(1, 5);
// 去掉整個sheet中的網格線
sheet.getSettings().setShowGridLines(false);
Label tempLabel = null;
// 表頭輸出
String[] headerArr = header.split(",");
int headerLen = headerArr.length;
// 循環寫入表頭內容
for (int i = 0; i < headerLen; i++) {
tempLabel = new Label(1 + i, 1, headerArr[i],
getHeaderCellStyle());
sheet.addCell(tempLabel);
}
// 表體輸出
int bodyLen = body.length;
// 循環寫入表體內容
for (int j = 0; j < bodyLen; j++) {
String[] bodyTempArr = body[j].split(",");
for (int k = 0; k < bodyTempArr.length; k++) {
WritableCellFormat tempCellFormat = null;
tempCellFormat = getBodyCellStyle();
if (tempCellFormat != null) {
if (k == 0 || k == (bodyTempArr.length - 1)) {
tempCellFormat.setAlignment(Alignment.CENTRE);
}
}
tempLabel = new Label(1 + k, 2 + j, bodyTempArr[k],
tempCellFormat);
sheet.addCell(tempLabel);
}
}
book.write();
book.close();
} catch (IOException e) {
createFlag = false;
System.out.println("EXCEL建立失敗!");
e.printStackTrace();
} catch (RowsExceededException e) {
createFlag = false;
System.out.println("EXCEL單元設定建立失敗!");
e.printStackTrace();
} catch (WriteException e) {
createFlag = false;
System.out.println("EXCEL寫入失敗!");
e.printStackTrace();
}
return createFlag;
}
public WritableCellFormat getHeaderCellStyle() {
WritableFont font = new WritableFont(WritableFont.createFont("宋體"), 10,
WritableFont.BOLD, false, UnderlineStyle.NO_UNDERLINE);
WritableCellFormat headerFormat = new WritableCellFormat(
NumberFormats.TEXT);
try {
// 新增字體設定
headerFormat.setFont(font);
// 設定儲存格背景色:表頭為黃色
headerFormat.setBackground(Colour.YELLOW);
// 設定表頭表格邊框樣式
// 整個表格線為粗線、黑色
headerFormat.setBorder(Border.ALL, BorderLineStyle.THICK,
Colour.BLACK);
// 表頭內容水平居中顯示
headerFormat.setAlignment(Alignment.CENTRE);
} catch (WriteException e) {
System.out.println("表頭儲存格樣式設定失敗!");
}
return headerFormat;
}
public WritableCellFormat getBodyCellStyle() {
WritableFont font = new WritableFont(WritableFont.createFont("宋體"), 10,
WritableFont.NO_BOLD, false, UnderlineStyle.NO_UNDERLINE);
WritableCellFormat bodyFormat = new WritableCellFormat(font);
try {
// 設定儲存格背景色:表體為白色
bodyFormat.setBackground(Colour.WHITE);
// 設定表頭表格邊框樣式
// 整個表格線為細線、黑色
bodyFormat
.setBorder(Border.ALL, BorderLineStyle.THIN, Colour.BLACK);
} catch (WriteException e) {
System.out.println("表體單元格樣式設定失敗!");
}
return bodyFormat;
}
public static void main(String[] args) {
String header = "NO,姓名,性別,年齡";
String[] body = new String[4];
body[0] = "1,歐陽鋒,男,68";
body[1] = "2,黃藥師,男,67";
body[2] = "3,洪七公,男,70";
body[3] = "4,郭靖,男,32";
String filePath = "e:/test.xls";
JxlTable testJxl = JxlTable.getInstance();
boolean flag = testJxl.createTable(header, body, filePath);
if (flag) {
System.out.println("表格建立成功!!");
}
}
}
分步講解:
讀取excel文件
要讀取excel檔案首先應該建立一個wordbook:
複製代碼代碼如下:
Workbook wb=Workbook.getWorkbook(File file);
Workbook wb=Workbook.getWorkbook(InputStream is);
然後就可以取得它的工作表:
複製代碼代碼如下:
Sheet[] sheets=wb.getSheets(); //取得所有工作表
Sheet sheet=wb.getSheet(0); //表示取得第一個工作表。
最後就可以得到某工作表的某些儲存格的值:
複製代碼代碼如下:
Cell cell=sheet.getCell(0,0); //取得第一列第一行的資料。第一個參數為列
String value=cell.getContents(); //取得該儲存格的字串形式的值
String type=cell.getType(); //取得該儲存格的資料型別。
關閉workbook工作流程:
當你完成對Excel電子表格資料的處理後,一定要使用close()方法來關閉先前建立的對象,以釋放讀取資料表的過程中所佔用的記憶體空間,在讀取大量資料時顯得尤為重要。參考如下程式碼片段:
複製代碼代碼如下:
wb.close();
注意:只有完成對該excel的操作後才可以關閉,關閉後在呼叫如Sheet s=wb.getSheet(0)會為null的。
常用的方法介紹:
Workbook類別提供的方法
1. int getNumberOfSheets()
取得工作薄(Workbook)中工作表(Sheet)的個數,範例:
複製代碼代碼如下:
jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
int sheets = rwb.getNumberOfSheets();
2. Sheet[] getSheets()
傳回工作薄(Workbook)中工作表(Sheet)物件數組,範例:
複製代碼代碼如下:
jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
Sheet[] sheets = rwb.getSheets();
Sheet介面提供的方法
1. String getName()
取得Sheet的名稱,範例:
複製代碼代碼如下:
jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
jxl.Sheet rs = rwb.getSheet(0);
String sheetName = rs.getName();
2. int getColumns()
取得Sheet表中所包含的總列數,範例:
複製代碼代碼如下:
jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
jxl.Sheet rs = rwb.getSheet(0);
int rsColumns = rs.getColumns();
3. Cell[] getColumn(int column)
取得某一列的所有儲存格,傳回的是儲存格物件數組,範例:
複製代碼代碼如下:
jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
jxl.Sheet rs = rwb.getSheet(0);
Cell[] cell = rs.getColumn(0);
4. int getRows()
取得Sheet表中所包含的總行數,範例:
複製代碼代碼如下:
jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
jxl.Sheet rs = rwb.getSheet(0);
int rsRows = rs.getRows();
5. Cell[] getRow(int row)