java創(chuàng)建excel示例(jxl使用方法)
使用該API非Windows操作系統(tǒng)也可以通過純Java應(yīng)用來處理Excel數(shù)據(jù)表。因?yàn)槭鞘褂?Java編寫的,所以我們在Web應(yīng)用中可以通過JSP、Servlet來調(diào)用API實(shí)現(xiàn)對Excel數(shù)據(jù)表的訪問。
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 {
// 根據(jù)路徑生成excel文件
book = Workbook.createWorkbook(new File(filePath));
// 創(chuàng)建一個sheet名為"表格"
WritableSheet sheet = book.createSheet("表格", 0);
// 設(shè)置NO列寬度
sheet.setColumnView(1, 5);
// 去掉整個sheet中的網(wǎng)格線
sheet.getSettings().setShowGridLines(false);
Label tempLabel = null;
// 表頭輸出
String[] headerArr = header.split(",");
int headerLen = headerArr.length;
// 循環(huán)寫入表頭內(nèi)容
for (int i = 0; i < headerLen; i++) {
tempLabel = new Label(1 + i, 1, headerArr[i],
getHeaderCellStyle());
sheet.addCell(tempLabel);
}
// 表體輸出
int bodyLen = body.length;
// 循環(huán)寫入表體內(nèi)容
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創(chuàng)建失?。?);
e.printStackTrace();
} catch (RowsExceededException e) {
createFlag = false;
System.out.println("EXCEL單元設(shè)置創(chuàng)建失??!");
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 {
// 添加字體設(shè)置
headerFormat.setFont(font);
// 設(shè)置單元格背景色:表頭為黃色
headerFormat.setBackground(Colour.YELLOW);
// 設(shè)置表頭表格邊框樣式
// 整個表格線為粗線、黑色
headerFormat.setBorder(Border.ALL, BorderLineStyle.THICK,
Colour.BLACK);
// 表頭內(nèi)容水平居中顯示
headerFormat.setAlignment(Alignment.CENTRE);
} catch (WriteException e) {
System.out.println("表頭單元格樣式設(shè)置失??!");
}
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 {
// 設(shè)置單元格背景色:表體為白色
bodyFormat.setBackground(Colour.WHITE);
// 設(shè)置表頭表格邊框樣式
// 整個表格線為細(xì)線、黑色
bodyFormat
.setBorder(Border.ALL, BorderLineStyle.THIN, Colour.BLACK);
} catch (WriteException e) {
System.out.println("表體單元格樣式設(shè)置失??!");
}
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("表格創(chuàng)建成功!!");
}
}
}
分步講解:
讀取excel文件
要讀取excel文件首先應(yīng)該建立一個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); //獲得第一列 第一行的數(shù)據(jù)。第一個參數(shù)為列
String value=cell.getContents(); //獲得該單元格的字符串形式的值
String type=cell.getType(); //獲得該單元格的數(shù)據(jù)類型。
關(guān)閉workbook工作流:
當(dāng)你完成對Excel電子表格數(shù)據(jù)的處理后,一定要使用close()方法來關(guān)閉先前創(chuàng)建的對象,以釋放讀取數(shù)據(jù)表的 過程中所占用的內(nèi)存空間,在讀取大量數(shù)據(jù)時顯得尤為重要。參考如下代碼片段:
wb.close();
注意:只有完成對該excel的操作后才可以關(guān)閉,關(guān)閉后在調(diào)用如Sheet s=wb.getSheet(0)會為null的。
常用的方法介紹:
Workbook類提供的方法
1. int getNumberOfSheets()
獲得工作?。╓orkbook)中工作表(Sheet)的個數(shù),示例:
jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
int sheets = rwb.getNumberOfSheets();
2. Sheet[] getSheets()
返回工作?。╓orkbook)中工作表(Sheet)對象數(shù)組,示例:
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表中所包含的總列數(shù),示例:
jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
jxl.Sheet rs = rwb.getSheet(0);
int rsColumns = rs.getColumns();
3. Cell[] getColumn(int column)
獲取某一列的所有單元格,返回的是單元格對象數(shù)組,示例:
jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
jxl.Sheet rs = rwb.getSheet(0);
Cell[] cell = rs.getColumn(0);
4. int getRows()
獲取Sheet表中所包含的總行數(shù),示例:
jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
jxl.Sheet rs = rwb.getSheet(0);
int rsRows = rs.getRows();
5. Cell[] getRow(int row)
- Java讀取Excel文件內(nèi)容的簡單實(shí)例
- Java數(shù)據(jù)導(dǎo)出功能之導(dǎo)出Excel文件實(shí)例
- java實(shí)現(xiàn)合并單元格的同時并導(dǎo)出excel示例
- java讀取excel文件并復(fù)制(copy)文件到指定目錄示例
- java常用工具類之Excel操作類及依賴包下載
- java實(shí)現(xiàn)excel導(dǎo)入數(shù)據(jù)的工具類
- JAVA使用POI獲取Excel的列數(shù)與行數(shù)
- java poi讀取excel操作示例(2個代碼)
- Java實(shí)現(xiàn)操作excel表格
- 在java poi導(dǎo)入Excel通用工具類示例詳解
- Java實(shí)現(xiàn)的Excel列號數(shù)字與字母互相轉(zhuǎn)換功能
相關(guān)文章
Spring 應(yīng)用中集成 Apache Shiro的方法
這篇文章主要介紹了Spring 應(yīng)用中集成 Apache Shiro的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05
IDEA集成Docker實(shí)現(xiàn)快捷部署的操作步驟
這篇文章主要介紹了IDEA集成Docker實(shí)現(xiàn)快捷部署的操作步驟,通過靈活利用這一功能,開發(fā)人員可以更快速地開發(fā)、調(diào)試和部署應(yīng)用程序,從而提高開發(fā)工作的效率和質(zhì)量,需要的朋友可以參考下2024-06-06
JDK8新特性-java.util.function-Function接口使用
這篇文章主要介紹了JDK8新特性-java.util.function-Function接口使用,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-04-04
SpringBoot數(shù)據(jù)訪問的實(shí)現(xiàn)
本文主要介紹了SpringBoot數(shù)據(jù)訪問的實(shí)現(xiàn),引入各種xxxTemplate,xxxRepository來簡化我們對數(shù)據(jù)訪問層的操作,感興趣的可以了解一下2023-11-11
MyBatis的@SelectProvider注解構(gòu)建動態(tài)SQL方式
這篇文章主要介紹了MyBatis的@SelectProvider注解構(gòu)建動態(tài)SQL方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-08-08
SpringBoot集成Quartz實(shí)現(xiàn)持久化定時接口調(diào)用任務(wù)
Quartz是功能強(qiáng)大的開源作業(yè)調(diào)度庫,幾乎可以集成到任何?Java?應(yīng)用程序中,從最小的獨(dú)立應(yīng)用程序到最大的電子商務(wù)系統(tǒng),本文將通過代碼示例給大家介紹SpringBoot集成Quartz實(shí)現(xiàn)持久化定時接口調(diào)用任務(wù),需要的朋友可以參考下2023-07-07
Java實(shí)現(xiàn)排球比賽計分系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了Java實(shí)現(xiàn)排球比賽計分系統(tǒng),具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06
Springcloud ribbon負(fù)載均衡算法實(shí)現(xiàn)
這篇文章主要介紹了Springcloud ribbon負(fù)載均衡算法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-04-04

