亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > Java > 正文

java創建excel示例(jxl使用方法)

2019-11-26 15:37:28
字體:
來源:轉載
供稿:網友

使用該API非Windows操作系統也可以通過純Java應用來處理Excel數據表。因為是使用 Java編寫的,所以我們在Web應用中可以通過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()
獲得工作?。╓orkbook)中工作表(Sheet)的個數,示例:

復制代碼 代碼如下:

jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
int sheets = rwb.getNumberOfSheets();

2. Sheet[] getSheets()
返回工作?。╓orkbook)中工作表(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)

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
97免费在线视频| 欧美大尺度电影在线观看| 精品成人久久av| 欧美日韩免费在线| 欧美日韩一区二区在线| 国产精品久久在线观看| 亚洲热线99精品视频| 国产精品久久久久久av福利| 日韩欧美一区二区三区| 国产精品久久久久久亚洲调教| 国产mv免费观看入口亚洲| 永久免费看mv网站入口亚洲| 国产亚洲欧美日韩精品| 日韩中文字幕国产精品| 亚洲欧美日本另类| 日韩视频免费大全中文字幕| 国产精品久久久久久久久久新婚| 欧美精品18videos性欧| 精品偷拍各种wc美女嘘嘘| 亚洲男人天堂2023| 日本三级韩国三级久久| 日韩中文字幕在线| 亚洲欧洲xxxx| 日韩精品高清在线观看| 日韩一区在线视频| 久久人人爽国产| 亚洲精品国产精品自产a区红杏吧| 国产成人精品免高潮在线观看| 欧美色视频日本高清在线观看| 日韩黄色在线免费观看| 69av视频在线播放| 国产日韩欧美自拍| 日韩激情av在线免费观看| 亚洲欧美国产精品va在线观看| 成人黄色av免费在线观看| 性夜试看影院91社区| 国产成人精品免费视频| 色婷婷成人综合| 国产精品久久久久9999| 精品久久久免费| 日本欧美精品在线| 国产视频观看一区| 国产精品久久久久久久久免费看| 原创国产精品91| 国产精品丝袜白浆摸在线| 欧美激情视频给我| 欧美日韩中文字幕在线视频| 国产拍精品一二三| 91麻豆国产精品| 黄网站色欧美视频| 亚洲在线一区二区| 欧美在线一级视频| 久久久亚洲欧洲日产国码aⅴ| 亚洲人成欧美中文字幕| 狠狠久久亚洲欧美专区| 久久99国产精品自在自在app| 国产在线播放不卡| 成人精品久久一区二区三区| 国产美女扒开尿口久久久| 日韩在线播放av| 亚洲欧洲xxxx| 中文字幕日韩av| 97人人爽人人喊人人模波多| 日本久久精品视频| 88xx成人精品| 久久九九有精品国产23| 欧美大片大片在线播放| 69精品小视频| 日韩经典一区二区三区| 亚洲成人999| 亚洲男人天堂2024| 欧美第一黄色网| 性亚洲最疯狂xxxx高清| 成人精品aaaa网站| 亚洲精品国产精品久久清纯直播| 国产小视频91| 最近2019中文免费高清视频观看www99| 成人网中文字幕| 一区二区日韩精品| 亚洲精品国精品久久99热一| 国产精品视频区| 亚洲综合中文字幕在线观看| 亚洲色图第三页| 国产精品久久久久久五月尺| 久久精品福利视频| 欧美激情2020午夜免费观看| 久久精品久久久久电影| 国产精品视频公开费视频| 国产精品视频内| 成人午夜小视频| 欧美视频在线观看免费| 国产精品福利在线观看| 亚洲国产精品99久久| 欧美日韩免费网站| 国产精品7m视频| 欧美日韩激情网| 国产成人+综合亚洲+天堂| 精品久久香蕉国产线看观看gif| 国产乱肥老妇国产一区二| 色哟哟网站入口亚洲精品| 国产精品视频不卡| 亚洲欧美日韩图片| 欧美激情亚洲一区| xxxx欧美18另类的高清| 国产精品吊钟奶在线| 久久视频在线播放| 国产精品影院在线观看| 日韩精品免费看| 亚洲男人天堂2019| 国产精品美女主播| 精品夜色国产国偷在线| 欧美日韩亚洲精品一区二区三区| 亚洲嫩模很污视频| 亚洲剧情一区二区| 国产精品日韩专区| 中文字幕亚洲激情| 亚洲free性xxxx护士hd| 日本亚洲欧洲色α| 奇门遁甲1982国语版免费观看高清| 亚洲电影免费在线观看| 日韩最新av在线| 国产91在线视频| 日韩在线观看免费全集电视剧网站| 久久久久久999| 91深夜福利视频| 久久99国产精品自在自在app| 欧美日韩精品在线观看| 国产精品久久久久999| 日韩欧美国产黄色| 久久精品久久久久电影| 久久久在线观看| 久久成人18免费网站| 日韩av手机在线| 成人黄色片网站| 日韩欧美国产免费播放| 日本a级片电影一区二区| 国产欧美一区二区白浆黑人| 久热精品视频在线| 激情懂色av一区av二区av| 在线观看国产精品91| 亚洲日本欧美中文幕| 国产精品电影网站| 青青草原成人在线视频| 中文字幕亚洲欧美日韩2019| 久久久久久久久综合| 欧美成人激情视频免费观看| 亚州欧美日韩中文视频| 欧美黑人国产人伦爽爽爽| 国产精品久久久久久久久免费| 在线观看久久久久久| 日韩视频在线免费观看| 美女999久久久精品视频| 国产成人一区二区三区小说| 国产主播欧美精品| 欧美日本国产在线| 亚洲一区二区久久| 亚洲精品97久久| 日韩电影视频免费| 日韩视频免费大全中文字幕| 日韩成人性视频| 亚洲aaa激情| 国产欧美精品xxxx另类| 久久久久久久影院| 欧美日本亚洲视频|