JAVA EXCEL API:是一開放源碼項目,通過它Java開發(fā)人員可以讀取Excel文件的內容、創(chuàng)建新的Excel文件、更新已經存在的Excel文件。使用該API非Windows操作系統也可以通過純Java應用來處理Excel數據表。因為它是使用Java編寫的,所以我們在Web應用中可以通過JSP、Servlet來調用API實現對Excel數據表的訪問。
下載:
Java Excel API的jar包可以通過以下URL獲得:
http:///projects/jexcelapi/files/jexcelapi/2.6.6/jexcelapi_2_6_6.zip/download
(包括所有版本):http:///projects/jexcelapi/files/
直接下載地址(迅雷上新建任務即可):
http://nchc.dl./project/jexcelapi/jexcelapi/2.6.6/jexcelapi_2_6_6.zip
示例1:讀取本地Excel文件F:\紅樓人物.xls
1. 新建Excel文件F:\紅樓人物.xls
內容如下:
2. Java通過jexcelapi包操作excel文件:
3. 結果:
① 控制臺輸出:
人物 等級 大觀園位置 金陵十二釵
林黛玉 小姐 瀟湘館 正冊
妙玉 世外 櫳翠庵 正冊
晴雯 丫鬟 怡紅院 副冊
香菱 妾 蘅蕪苑 又副冊
② 創(chuàng)建文件F:\紅樓人物1.xls
4. 程序解析:
所引用的包:
① Workbook對象,需要jxl.Workbook包;
② InputStream、FileInputStream對象:需要java.io.FileInputStream和java.io.InputStream包。
③ Sheet對象:jxl.Sheet包;注意excel中sheet表單的行列從0開始計數。
④ Cell對象:jxl.Cell包;對單元進行處理
⑤ Label:選擇jxl.write.label包
⑥ WritableWorkbook、WritableSheet、WritableCelll對象
實例二:3個功能-----從excel文件F:\紅樓人物.xls讀取數據;生成新的excel文件F:\紅樓人物2.xls;修改原excel一個單元并輸出為F:\紅樓人物3.xls。
原始文件:F:\紅樓人物.xls
運行結果:
① 控制臺輸出:
人物 等級 大觀園位置 金陵十二釵
林黛玉 小姐 瀟湘館 正冊
妙玉 世外 櫳翠庵 正冊
晴雯 丫鬟 怡紅院 副冊
香菱 妾 蘅蕪苑 又副冊
② 寫入輸出Excel文件:F:\紅樓人物2.xls
③ 修改輸出文件 F:\紅樓人物3.xls (加修飾后輸出)
示例程序:
- //in ExcelHandle
-
- import jxl.*;
-
- import jxl.format.UnderlineStyle;
-
- import jxl.write.*;
-
- import jxl.write.Number;
-
- import jxl.write.Boolean;
-
- import jxl.Cell;
-
-
-
- import java.io.*;
-
-
-
- public class ExcelHandle
-
- {
-
- public ExcelHandle()
-
- {
-
- }
-
- /***讀取Excel*/
-
- public static void readExcel(String filePath)
-
- {
-
- try
-
- {
-
- InputStream is = new FileInputStream(filePath);
-
- Workbook rwb = Workbook.getWorkbook(is);
-
- //這里有兩種方法獲取sheet表:名字和下標(從0開始)
-
- //Sheet st = rwb.getSheet("original");
-
- Sheet st = rwb.getSheet(0);
-
- /**
-
- //獲得第一行第一列單元的值
-
- 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);*/
-
- //Sheet的下標是從0開始
-
- //獲取第一張Sheet表
-
- Sheet rst = rwb.getSheet(0);
-
- //獲取Sheet表中所包含的總列數
-
- int rsColumns = rst.getColumns();
-
- //獲取Sheet表中所包含的總行數
-
- int rsRows = rst.getRows();
-
- //獲取指定單元格的對象引用
-
- for (int i = 0; i < rsRows; i++)
-
- {
-
- for (int j = 0; j < rsColumns; j++)
-
- {
-
- Cell cell = rst.getCell(j, i);
-
- System.out.print(cell.getContents() + " ");
-
- }
-
- System.out.println();
-
- }
-
- //關閉
-
- rwb.close();
-
- }
-
- catch(Exception e)
-
- {
-
- e.printStackTrace();
-
- }
-
- }
-
- /**輸出Excel*/
-
- public static void writeExcel(OutputStream os)
-
- {
-
- try
-
- {
-
- /** 只能通過API提供的
工廠方法來創(chuàng)建Workbook,而不能使用WritableWorkbook的構造函數,因為類WritableWorkbook的構造函數為
protected類型:方法一:直接從目標文件中讀取
WritableWorkbook wwb = Workbook.createWorkbook(new File(targetfile));方法
二:如下實例所示 將WritableWorkbook直接寫入到輸出流*/
-
- WritableWorkbook wwb = Workbook.createWorkbook(os);
-
- //創(chuàng)建Excel工作表 指定名稱和位置
-
- WritableSheet ws = wwb.createSheet("Test Sheet 1",0);
-
- /**************往工作表中添加數據*****************/
-
- //1.添加Label對象
-
- Label label = new Label(0,0,"測試");
-
- 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.DARK_YELLOW);
-
- WritableCellFormat wcfFC = new WritableCellFormat(wfc);
-
- Label labelCF = new Label(1,0,"Ok",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,true);
-
- ws.addCell(labelB);
-
- Boolean labelB1 = new jxl.write.Boolean(1,2,false);
-
- ws.addCell(labelB1);
-
- //4.添加DateTime對象
-
- jxl.write.DateTime labelDT = new jxl.write.DateTime(0,3,new java.util.Date());
-
- ws.addCell(labelDT);
-
-
-
- //5.添加帶有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);
-
- //6.添加圖片對象,jxl只支持png格式圖片
-
- File image = new File("f:\\1.png");
-
- WritableImage wimage = new WritableImage(0,4,6,17,image);
-
- ws.addImage(wimage);
-
- //7.寫入工作表
-
- wwb.write();
-
- wwb.close();
-
- }
-
- catch(Exception e)
-
- {
-
- e.printStackTrace();
-
- }
-
- }
-
- /** 將file1拷貝后,進行修改并創(chuàng)建輸出對象file2
-
- * 單元格原有的格式化修飾不能去掉,但仍可將新的單元格修飾加上去,
-
- * 以使單元格的內容以不同的形式表現
-
- */
-
- public static void modifyExcel(File file1,File file2)
-
- {
-
- try
-
- {
-
- Workbook rwb = Workbook.getWorkbook(file1);
-
- WritableWorkbook wwb = Workbook.createWorkbook(file2,rwb);//copy
-
- WritableFont wfc = new WritableFont(WritableFont.ARIAL,10,WritableFont.NO_BOLD,false,
-
- UnderlineStyle.NO_UNDERLINE,jxl.format.Colour.BLUE);
-
- WritableCellFormat wcfFC = new WritableCellFormat(wfc);
-
- WritableSheet ws = wwb.getSheet(0);
-
- WritableCell wc = ws.getWritableCell(0,0);
-
- //判斷單元格的類型,做出相應的轉換
-
- if(wc.getType() == CellType.LABEL)
-
- {
-
- Label labelCF =new Label(0,0,"人物(新)",wcfFC);
-
- ws.addCell(labelCF);
-
- //Label label = (Label)wc;
-
- //label.setString("被修改");
-
- }
-
- wwb.write();
-
- wwb.close();
-
- rwb.close();
-
- }
-
- catch(Exception e)
-
- {
-
- e.printStackTrace();
-
- }
-
- }
-
- //測試
-
- public static void main(String args[])
-
- {
-
- try
-
- {
-
- //讀EXCEL
-
- ExcelHandle.readExcel("F:/紅樓人物.xls");
-
- //輸出EXCEL
-
- File filewrite=new File("F:/紅樓人物2.xls");
-
- filewrite.createNewFile();
-
- OutputStream os=new FileOutputStream(filewrite);
-
- ExcelHandle.writeExcel(os);
-
- //修改EXCEL
-
- ExcelHandle.modifyExcel(new File("F:/紅樓人物.xls"), new File("F:/紅樓人物3.xls"));
-
- }
-
- catch(Exception e)
-
- {
-
- e.printStackTrace();
-
- }
-
- }
-
- }
-
附:
調用流程如下:
1.打開工作文件Workbook,在此之前先用java的io流創(chuàng)建或者讀取文件 2.打開工作表Sheet 3.讀行,然后讀列。注意,行和列是從零開始的 4.取得數據進行操作
來自網絡à讀取Excel數據表
第一步:創(chuàng)建Workbook(術語:工作薄)
2種方法:Workbook,就可以通過它來訪問Excel Sheet(術語:工作表):
- //從輸入流創(chuàng)建Workbook讀取excel數據表
-
- InputStream is = new FileInputStream(sourcefile);
-
- jxl.Workbook workbook = Workbook.getWorkbook(is);
-
- //直接從本地文件(.xls)創(chuàng)建Workbook
-
- Workbook workbook = Workbook.getWorkbook(new File(excelfile));
一旦創(chuàng)建了
第二步:訪問sheet。
2種方法:通過sheet的名稱;或者通過下標,下標從0開始。
- //獲取第一張Sheet表
-
- Sheet rs = workbook.getSheet(0);
-
- 一旦得到了Sheet,就可以通過它來訪問Excel Cell(術語:單元格)。
-
- 第三步:訪問單元格cell
-
- //獲取第一行,第一列的值
-
- 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的 值,我們可以方便地通過getContents()方法,它可以將任何類型的Cell值都作為一個字符串返回。如果有需要知道Cell內容的確切類型,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());
-
在得到
循環(huán)取出全部數據,并轉化為相應格式:
- int rows = sheet.getRows();
-
- for (int i = 1; i < rows; i++) {
-
- Cell cb1 = sheet.getCell(0, i);
-
- Cell cb2 = sheet.getCell(1, i);
-
- Cell num3 = sheet.getCell(2, i);
-
- Cell num4 = sheet.getCell(3, i);
-
-
-
- String user = "";
-
- String rule = "";
-
- int numNew = 0;
-
- int numEdit = 0;
-
- if (cb1.getType() == CellType.LABEL) {
-
- LabelCell lc = (LabelCell) cb1;
-
- user = lc.getString();
-
- }
-
- if (cb2.getType() == CellType.LABEL) {
-
- LabelCell lc = (LabelCell) cb2;
-
- rule = lc.getString();
-
- }
-
- if (num3.getType() == CellType.NUMBER_FORMULA) {
-
- NumberFormulaCell nc = (NumberFormulaCell) num3;
-
- try {
-
- numNew = Double.valueOf(nc.getFormula()).intValue();
-
- } catch (FormulaException e) {
-
- e.printStackTrace();
-
- }
-
- }
-
- if (num4.getType() == CellType.NUMBER_FORMULA) {
-
- NumberFormulaCell nc = (NumberFormulaCell) num4;
-
- try {
-
- numEdit = Double.valueOf(nc.getFormula()).intValue();
-
- } catch (FormulaException e) {
-
- e.printStackTrace();
-
- }
-
- }
-
- }
-
第五步:關閉對象,釋放內存。
完成對Excel電子表格數據的處理后,一定要使用close()方法來關閉先前創(chuàng)建的對象,以釋放讀取數據表的過程中所占用的內存空間,在讀取大量數據時顯得尤為重要。
Cell對象后,通過 getType()方法可以獲得該單元格的類型,然后與API提供的基本類型相匹配,強制轉換成相應的類型,最后調用相應的取值方法getXXX(),就可以得到確定類型的值。
|