Jxl使用總結(jié)
Jxl是一個開源的Java Excel API項(xiàng)目,通過Jxl,Java可以很方便的操作微軟的Excel文檔。除了Jxl之外,還有Apache的一個POI項(xiàng)目,也可以操作Excel,兩者相比之下:Jxl使用方便,但功能相對POI比較弱。POI使用復(fù)雜,上手慢,除了這個沒啥說的了。
Jxl目前最新2.6.10,下載地址是:
http://www./jexcelapi/
API總結(jié)
1、創(chuàng)建或讀取一個工作薄 Workbook
創(chuàng)建一個工作薄,就是整個Excel文檔,
WritableWorkbook wwb = Workbook.createWorkbook(os);
其中os為一個文件輸出流。當(dāng)然還有很多其他的入?yún)?,比如File等。
Workbook不但能用來創(chuàng)建工作薄,也可以讀取現(xiàn)有的工作薄,比如:
Workbook.getWorkbook(java.io.File file);
Workbook是一個很重要工具類,里面方法基本上都是static的,使用方便。
2、創(chuàng)建工作表 Sheet
創(chuàng)建工作表的方式是通過上面創(chuàng)建的WritableWorkbook對象來操作。
創(chuàng)建一個工作表:
createSheet(java.lang.String name, int index),
兩個參數(shù)分別是工作表名字和插入位置,這個位置從0開始,比如:
WritableSheet sheet = wwb.createSheet("演員表", 0);
3、創(chuàng)建標(biāo)簽 Label
實(shí)際上標(biāo)簽這里的意思就是工作表的單元格,這個單元格多種,分別對應(yīng)不同的類,比如jxl.write.Boolean、jxl.write.Boolean等。
Label label = new Label(col, row, title);
三個參數(shù)分別表示col+1列,row+1行,標(biāo)題內(nèi)容是title。
將標(biāo)簽加入到工作表中
sheet.addCell(label);
4、填充數(shù)據(jù)
數(shù)據(jù)填充這塊稍微復(fù)雜點(diǎn),涉及到數(shù)據(jù)單元格的格式問題。
a)、填充數(shù)字
jxl.write.Number numb = new jxl.write.Number(1, 1, 250);
sheet.addCell(numb); b)、填充格式化的數(shù)字
jxl.write.NumberFormat nf = new jxl.write.NumberFormat("#.##");
jxl.write.WritableCellFormat wcf = new jxl.write.WritableCellFormat(nf); jxl.write.Number n = new jxl.write.Number(2, 1, 2.451, wcf); sheet.addCell(n); c)、填充日期
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd hh:mm:ss");
String newdate = sdf.format(new Date()); label = new Label(2, 2, newdate); sheet.addCell(label); d)、填充文本
label = new Label(3, 3, "周星馳");
sheet.addCell(label); e)、填充boolean值
jxl.write.Boolean bool = new jxl.write.Boolean(4, 1, true);
sheet.addCell(bool); 5、合并單元格
通過writablesheet.mergeCells(int x,int y,int m,int n);來實(shí)現(xiàn)的。
表示將從第x+1列,y+1行到m+1列,n+1行合并 (四個點(diǎn)定義了兩個坐標(biāo),左上角和右下角)
結(jié)果是合并了m-x+1行,n-y+1列,兩者乘積就是合并的單元格數(shù)量。
sheet.mergeCells(0, 6, 3, 8);
label = new Label(0, 6, "合并了12個單元格"); sheet.addCell(label); 6、添加單元格的式樣
主要是改變單元格背景、字體、顏色等等。
WritableCellFormat wc = new WritableCellFormat();
// 設(shè)置居中 wc.setAlignment(Alignment.CENTRE); // 設(shè)置邊框線 wc.setBorder(Border.ALL, BorderLineStyle.THIN); // 設(shè)置單元格的背景顏色 wc.setBackground(jxl.format.Colour.RED); label = new Label(1, 5, "字體", wc); sheet.addCell(label); 7、設(shè)置單元格字體
// 設(shè)置字體
jxl.write.WritableFont wfont = new jxl.write.WritableFont(WritableFont.createFont("楷書"), 20); WritableCellFormat font = new WritableCellFormat(wfont); label = new Label(2, 6, "楷書", font); sheet.addCell(label); 8、將工作寫成文件
// 寫入數(shù)據(jù)
wwb.write(); // 關(guān)閉文件 wwb.close(); 9、行列的批量操作
//獲取所有的工作表
jxl.write.WritableSheet[] sheetList = wwb.getSheets(); //獲取第1列所有的單元格 jxl.Cell[] cellc = sheet.getColumn(0); //獲取第1行所有的單元格 jxl.Cell[] cellr = sheet.getRow(0); //獲取第1行第1列的單元格 Cell c = sheet.getCell(0, 0); 10、獲取單元格的值
//獲取單元格的值,不管什么單元格,返回都是字符串
String value = c.getContents(); |
|