亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時(shí)間:2014年03月07日 14:22:28   作者:  
Java Excel是一開放源碼項(xiàng)目,通過它Java開發(fā)人員可以讀取Excel文件的內(nèi)容、創(chuàng)建新的Excel文件、更新 已經(jīng)存在的Excel文件。下面是使用方法,包括去掉網(wǎng)格線、字體設(shè)置、單元格設(shè)置、對(duì)齊方式等設(shè)置

使用該API非Windows操作系統(tǒng)也可以通過純Java應(yīng)用來處理Excel數(shù)據(jù)表。因?yàn)槭鞘褂?Java編寫的,所以我們?cè)赪eb應(yīng)用中可以通過JSP、Servlet來調(diào)用API實(shí)現(xiàn)對(duì)Excel數(shù)據(jù)表的訪問。

復(fù)制代碼 代碼如下:

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)建一個(gè)sheet名為"表格"
   WritableSheet sheet = book.createSheet("表格", 0);
   // 設(shè)置NO列寬度
   sheet.setColumnView(1, 5);
   // 去掉整個(gè)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è)置表頭表格邊框樣式
   // 整個(gè)表格線為粗線、黑色
   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è)置表頭表格邊框樣式
   // 整個(gè)表格線為細(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,歐陽(yáng)鋒,男,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)該建立一個(gè)wordbook:

復(fù)制代碼 代碼如下:

Workbook wb=Workbook.getWorkbook(File file);
Workbook wb=Workbook.getWorkbook(InputStream is);

然后就可以獲得它的工作表

復(fù)制代碼 代碼如下:

Sheet[] sheets=wb.getSheets();            //獲得所有工作表
Sheet sheet=wb.getSheet(0);               //表示獲得第一個(gè)工作表。

最后就可以獲得對(duì)某工作表的某些單元格的值:

復(fù)制代碼 代碼如下:

Cell cell=sheet.getCell(0,0);          //獲得第一列 第一行的數(shù)據(jù)。第一個(gè)參數(shù)為列
String value=cell.getContents();    //獲得該單元格的字符串形式的值
String type=cell.getType();           //獲得該單元格的數(shù)據(jù)類型。

關(guān)閉workbook工作流
當(dāng)你完成對(duì)Excel電子表格數(shù)據(jù)的處理后,一定要使用close()方法來關(guān)閉先前創(chuàng)建的對(duì)象,以釋放讀取數(shù)據(jù)表的 過程中所占用的內(nèi)存空間,在讀取大量數(shù)據(jù)時(shí)顯得尤為重要。參考如下代碼片段:

復(fù)制代碼 代碼如下:

wb.close();

注意:只有完成對(duì)該excel的操作后才可以關(guān)閉,關(guān)閉后在調(diào)用如Sheet s=wb.getSheet(0)會(huì)為null的。

常用的方法介紹

Workbook類提供的方法
1. int getNumberOfSheets()
獲得工作?。╓orkbook)中工作表(Sheet)的個(gè)數(shù),示例:

復(fù)制代碼 代碼如下:

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

2. Sheet[] getSheets()
返回工作薄(Workbook)中工作表(Sheet)對(duì)象數(shù)組,示例:

復(fù)制代碼 代碼如下:

jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
Sheet[] sheets = rwb.getSheets();


Sheet接口提供的方法

1. String getName()
獲取Sheet的名稱,示例:

復(fù)制代碼 代碼如下:

jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
jxl.Sheet rs = rwb.getSheet(0);
String sheetName = rs.getName();

2. int getColumns()
獲取Sheet表中所包含的總列數(shù),示例:

復(fù)制代碼 代碼如下:

jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
jxl.Sheet rs = rwb.getSheet(0);
int rsColumns = rs.getColumns();

3. Cell[] getColumn(int column)
獲取某一列的所有單元格,返回的是單元格對(duì)象數(shù)組,示例:

復(fù)制代碼 代碼如下:

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ù),示例:

復(fù)制代碼 代碼如下:

jxl.Workbook rwb = jxl.Workbook.getWorkbook(new File(sourcefile));
jxl.Sheet rs = rwb.getSheet(0);
int rsRows = rs.getRows();

5. Cell[] getRow(int row)

相關(guān)文章

  • 詳解如何配置Spring Batch批處理失敗重試機(jī)制

    詳解如何配置Spring Batch批處理失敗重試機(jī)制

    這篇文章主要來和大家一起探討一下如何在Spring批處理框架中配置重試邏輯,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以跟隨小編一起學(xué)習(xí)一下
    2023-06-06
  • Java自定義簡(jiǎn)單標(biāo)簽實(shí)例

    Java自定義簡(jiǎn)單標(biāo)簽實(shí)例

    Java自定義簡(jiǎn)單標(biāo)簽可以方便的在頁(yè)面輸出信息,并且對(duì)于權(quán)限的控制,和對(duì)于Jsp標(biāo)簽和servlet代碼的分離有著很好的作用
    2013-07-07
  • SpringMVC實(shí)現(xiàn)文件上傳下載功能

    SpringMVC實(shí)現(xiàn)文件上傳下載功能

    這篇文章主要為大家詳細(xì)介紹了springMVC實(shí)現(xiàn)文件上傳和下載的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • Mybatis逆工程的使用

    Mybatis逆工程的使用

    最近在學(xué)Mybatis,類似Hibernate,Mybatis也有逆工程可以直接生成代碼(mapping,xml,pojo),方便快速開發(fā)。這篇文章給大家介紹Mybatis逆工程的使用相關(guān)知識(shí),感興趣的朋友一起看下吧
    2016-06-06
  • Mybatis plus關(guān)閉駝峰命名的四種方法(防止出現(xiàn)查詢?yōu)镹ull)

    Mybatis plus關(guān)閉駝峰命名的四種方法(防止出現(xiàn)查詢?yōu)镹ull)

    這篇文章主要介紹了Mybatis plus關(guān)閉駝峰命名的四種方法(防止出現(xiàn)查詢?yōu)镹ull),數(shù)據(jù)庫(kù)的字段命名方式為使用下劃線連接,對(duì)應(yīng)的實(shí)體類應(yīng)該是駝峰命名方式,而我使用的是和數(shù)據(jù)庫(kù)同樣的命名方式,需要的朋友可以參考下
    2022-01-01
  • java生成pdf表格,調(diào)用itext創(chuàng)建的實(shí)例

    java生成pdf表格,調(diào)用itext創(chuàng)建的實(shí)例

    這篇文章主要介紹了java生成pdf表格,調(diào)用itext創(chuàng)建的實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • 2020Mac M1安裝jdk和IDEA的詳細(xì)方法

    2020Mac M1安裝jdk和IDEA的詳細(xì)方法

    這篇文章主要介紹了2020Mac M1安裝jdk和IDEA的詳細(xì)方法,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-03-03
  • PageHelper分頁(yè)查詢操作方法示例

    PageHelper分頁(yè)查詢操作方法示例

    這篇文章主要為大家介紹了PageHelper分頁(yè)查詢數(shù)據(jù)操作方法示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • Spring在代碼中獲取bean的幾種方式詳解

    Spring在代碼中獲取bean的幾種方式詳解

    這篇文章主要介紹了Spring在代碼中獲取bean的幾種方式詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-08-08
  • 使用res:bean屬性復(fù)制避免null值覆蓋版本

    使用res:bean屬性復(fù)制避免null值覆蓋版本

    這篇文章主要介紹了使用res:bean屬性復(fù)制避免null值覆蓋版本的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-08-08

最新評(píng)論