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

使用该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()
获得工作薄(Workbook)中工作表(Sheet)的个数,示例:


代码如下:

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

2. Sheet[] getSheets()
返回工作薄(Workbook)中工作表(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)

(0)

相关推荐

  • java 中JXL操作Excel实例详解

    JXL操作Excel 前言: jxl是一个韩国人写的java操作excel的工具, 在开源世界中,有两套比较有影响的API可 供使用,一个是POI,一个是jExcelAPI.其中功能相对POI比较弱一点.但jExcelAPI对中文支持非常好,API是纯Java的, 并不 依赖Windows系统,即使运行在Linux下,它同样能够正确的处理Excel文件. 另外需要说明的是,这套API对图形和图表的支持很有限,而且 仅仅识别PNG格式. 使用如下: 搭建环境 将下载后的文件解包,得到jxl.jar

  • Java使用jxl包写Excel文件适合列宽实现

    注意,这个只是基本可以实现,基本针对中文电子报表. 1.实现思路(1)一般的中文汉字占位长度是英文字母的2倍,"方块字"很统一.(2)对于要写入Excel中的数据统计每一列的最大列宽,最后直接将这一列的列宽设置为这个列的最大值即可. 2.实现代码 复制代码 代码如下: import java.io.File;import java.util.ArrayList;import java.util.List;import java.util.regex.Matcher;import jav

  • Java用jxl读取excel并保存到数据库的方法

    项目中涉及到读取excel中的数据,保存到数据库中,用jxl做起来比较简单. 基本的思路: 把excel放到固定盘里,然后前段页面选择文件,把文件的名字传到后台,再利用jxl进行数据读取,把读取到的数据存到list中,通过遍历list,得到map,存到数据库中. 首先导入jar包:在网上都有, 代码: 页面: 新模excel导入 <input type="file" name="excel" id="xinmu"> <input

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

    使用该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.for

  • Java创建并运行线程的方法

    Java线程类也是一个object类,它的实例都继承自java.lang.Thread或其子类. 可以用如下方式用java中创建一个线程: Tread thread = new Thread(); 执行该线程可以调用该线程的start()方法: thread.start(); 在上面的例子中,我们并没有为线程编写运行代码,因此调用该方法后线程就终止了. 编写线程运行时执行的代码有两种方式:一种是创建Thread子类的一个实例并重写run方法,第二种是创建类的时候实现Runnable接口.接下来我

  • Java操作excel的三种常见方法实例

    前言 在平时的业务系统开发中,少不了需要用到导出.导入excel功能,今天我们就一起来总结一下! 下面给大家介绍一下几种常用方法: apache poi easypoi easyexcel 一.Apache poi 大概在很久很久以前,微软的电子表格软件 Excel 以操作简单.存储数据直观方便,还支持打印报表,在诞生之初,可谓深得办公室里的白领青睐,极大的提升了工作的效率,不久之后,便成了办公室里的必备工具. 随着更多的新语言的崛起,例如我们所熟悉的 java,后来便有一些团队开始开发一套能与

  • Java 创建线程的两个方法详解及实例

    Java 创建线程的两个方法 Java提供了线程类Thread来创建多线程的程序.其实,创建线程与创建普通的类的对象的操作是一样的,而线程就是Thread类或其子类的实例对象.每个Thread对象描述了一个单独的线程.要产生一个线程,有两种方法: ◆需要从Java.lang.Thread类派生一个新的线程类,重载它的run()方法: ◆实现Runnalbe接口,重载Runnalbe接口中的run()方法. 为什么Java要提供两种方法来创建线程呢?它们都有哪些区别?相比而言,哪一种方法更好呢?

  • Java 创建动态类和查看方法列表信息的实例

     Java 创建动态类和查看方法列表信息的实例 Sample code : import java.lang.reflect.Constructor; import java.lang.reflect.InvocationHandler; import java.lang.reflect.Method; import java.lang.reflect.Proxy; import java.lang.reflect.Type; import java.util.ArrayList; import

  • Java创建ZIP压缩文件的方法

    本文实例讲述了Java创建ZIP压缩文件的方法.分享给大家供大家参考.具体如下: 这里注意:建议使用org.apache.tools.zip.*包下相关类,否则可能会出现中文乱码问题. /** * 压缩文件夹 * @param sourceDIR 文件夹名称(包含路径) * @param targetZipFile 生成zip文件名 * @author liuxiangwei */ public static void zipDIR(String sourceDIR, String target

  • Java 创建线程的3种方法及各自的优点

    1. 继承 Thread 类,然后调用 start 方法. class MyThread extends Thread { //重写run方法,线程运行后,跑的就是run方法 public void run(){ //System.out.println(""); } public static void main(String[] args){ Thread t1 = new MyThread(); t1.start(); //线程运行,调用的 run()方法. } } 2. 实现

  • Java 将Excel转为SVG的方法

    1. 程序运行环境如下: 编译工具:IDEA JDK版本:1.8.0 Excel测试文档:.xlsx 2013 Excel工具jar包:free spire.xls.jar 3.9.1 2.关于如何导入jar包 方法1:手动下载jar包.解压,将文件路径:D:\...\Spire.Xls-FE_3.9.1\lib\Spire.Xls.jar中的文件导入Java程序(即本文中使用的方法). 方法2:Maven仓库下载导入.先在maven程序中配置pom.xml文件,如下内容: <repositor

  • 一文搞懂Java创建线程的五种方法

    目录 题目描述 解题思路 代码详解 第一种 继承Thread类创建线程 第二种:实现Runnable接口创建线程 第三种:实现Callable接口,通过FutureTask包装器来创建Thread线程 第四种:使用ExecutorService.Callable(或者Runnable).Future实现返回结果的线程 第五种:使用ComletetableFuture类创建异步线程,且是据有返回结果的线程 题目描述 Java创建线程的几种方式 Java使用Thread类代表线程,所有线程对象都必须

  • Java创建型设计模式之工厂方法模式深入详解

    目录 简单工厂模式 定义产品对象 创建工厂类 工厂使用反射 工厂方法模式 概述 应用场景 优缺点 主要角色 工厂方法模式的基本使用 创建抽象产品 创建具体产品 创建抽象工厂 创建具体工厂 客户端执行 简单工厂模式 简单工厂模式(Simple Factory Pattern)是指由一个工厂对象决定创建出哪一种产品类的实例,但是它不属于设计模式. 简单工厂适用于工厂类负责创建的对象较少的场景,且客户端只需要传入工厂类的参数,对于如何创建对象的逻辑不需要关心. 定义产品对象 public interf

随机推荐