[<摘自>飞:jxl简析:http://www.emlog.net/fei]

(二)应用

在进行实践前 , 我们需要对 excel 有一个大致的了解 ,excel 文件由一个工作簿 (Workbook) 组成 , 工作簿由工作表 (sheet) 组成 , 每个工作表又由很多单元格 (cell) 组成 . 工作簿有自己的特征 , 同样工作表 , 单元格也一样 . 从大局上了解了 excel 文件 , 对于我们更好的使用 jxl 是有一定的帮助的 . 具体请查看(一) API

在 jxl 中其大概的层次是这样的

名称

属性

Workbook

WorkbookSettings

Sheet

SheetSettings

Cell

CeLlFormat CellFeatures CellView CellType

Jxl 读 excel :

得到工作簿的方法主要有四个 :

getWorkbook(File file)

getWorkbook(File file,WorkSettings ws)

getWorkbook(InputStream is)

getWorkbook(InputStream is,WorkSettings ws)

参数有两个 :

第一个参数是必须的 : 文件或输入流 ,

第二个参数 : 工作簿 ws 是作为读出来的 excel 的一些约定 , 如地区 , 编码等 .

如果文件错误或格式错误 , 将会抛出 BiffException 或 IOException.

代码段 :

Workbook wb=null;

try

{

wb = Workbook.getWorkbook(excelFile);

wb.close();

}

catch(BiffException ex){

// 转换错误

}catch(IOException ex){

//IO 错误

}

以上如果一切正常的话 , 将得到此 excel 文件的工作簿 . 接下来我们就可以通过此文件簿得到其他的东西了 . 以下是得到工作表有关的方法

int getNumberOfSheets()// 工作表个数

Sheet getSheet(String  name);// 得到此对应名称的工作表

Sheet getSheet(int index);// 得到此序列号的工作表

Sheet[] getSheets();// 得到工作表数组

String[] getSheetNames();// 得到工作表名称数组

示例代码如下:

Sheet sheet;

if(wb.getNumberOfSheets()>0)

{

sheet = wb.getSheet(0);

}

以下的方法除非特别目的,否则用到的地方不多.

Range[] finaName(String name);// 得到此名称的表格区

Cell findCellByName(String name);// 得到此名称的 Cell

Cell getCell(String loc)

String[] getRangeNames();

与文件是否可写有关的

boolean isProected();

得到了工作簿文件的某个工作表时.

对于工作表而言其主要的内容就是单元格了.

// 根据内容查看

Cell findCell(Pattern pattern,int firstCol,int firstRow,int lastCol,int lastRow,Boolean reverse)

Cell findCell(String content)

Cell findCell(String content,omt forstCol,int firstRow,int lastCol,int lastRow,Boolean reverse)

LabelCell findLabelCell(String contents)

// 根据位置得到

Cell getCell(int col,int row)

Cell getCell(String loc)//loc 的格式为 A3/B1/C3 其相同于

getCell(CellReferenceHelper.getColumn(loc0,CellReferenceHelper.getRow(loc)), 所以相对而言其性能没有 Cell getCell(int col,int row) 快

// 单元格数组

Cell[] getRows(int row)// 当前行单元格数组

Cell[] getCols(int col)// 当前列单元格数组

// 特殊单元格数组

// 超链接表格

Hyperlink[] getHyperlinks();// 超链接数组

// 区域表格

Range[] getMergedCells();// 区域单元格数组

// 图像表格

Int getNumberOfImages()// 拥有图片数

Image getDrawing(int index)// 对应序号的图片

// 工作表或多个表格一些自我属性

String getName()// 工作表名

int getRows()// 行数

int getCols()// 列数

SheetSettings getSettings()// 工作表设置

CellView getColumnView(int col)// 此列的表格视图

CellView getRowView(int row)// 此行的表格视图

以下是与单元格有关的一些操作:

CellFeatures getCellFeatures()// 主要是与表格内容有关的一些性质如验证等

CellFormat getCellFormat()// 主要是表格外在表现格式有关的一些性质.

int getColumn()// 所在列

int getRow()// 所在行

String getContents();// 内容

boolean  isHidden();// 可见否

CellType getType();// 表格类型 如果不确定表格如果转换则可以使用此方法来确定表格类型.

以下我们讲述如何写 excel 文件.

写文件分为两种情况 一种是新建一种则是更新.

新建 excel 文件

新建 excel 文件很简单:

// 文件

WritableWorkbook createWorkbook(File file) // 无形式的创建一个 excel 文件

WritableWorkbook createWorkbook(File file Workbook in)

// 以 in 一样的格式创建一个 excel 文件,其初始内容与 in 文件相同 ( 更新文件可以用到此方法 )

WriteableWorkbook createWorkbook(File file,WorkSetting ws)// 以 ws 的设定创建文件

WritableWorkbook createWorkbook(File file,Workbook in,WorkSetting ws)

// 以 ws 的设定创建一个与 in 文件相同的文件

// 流

WritableWorkbook createWorkbook(OutputStream os)

WritableWorkbook createWorkbook(OutputStream os Workbook in)

WriteableWorkbook createWorkbook(OutputStream os,WorkSetting ws)

WritableWorkbook createWorkbook(OutputStream os,Workbook in,WorkSetting ws)

代码示例:

WritableWorkbook wrb;

WriteableWorkbook wrbin;

try

{

wrb =  Workbook.createWorkbook(targetfile);

wrbin = Workbook.createWorkbook(targetfile,wb);

}

catch (IOexception e)

{

//IO 错误

}

当创建好工作簿时,我们就需要新建工作表了

WritableSheet createSheet(String name,int index);

WritableSheet wrs  = wrb.createSheet(“demo”,0);

// 创建一个名为 demo 的工作表,其为工作簿的第一个工作表.

接下来我们就可以进行其他操作了

添加文本类单元格:

Label   label = new Label(0,0,””);

wrb.addCell (label);

// 添加数据单元格

Number number = new Number(0,3,1234);

wrb.addCell (number);

// 添加时间单元格

DateTime dt = new DateTime(0,4,new Date());

Wrb.addCell (dt);

// 添加公式单元格

Fornual formual = new Formual(0,11,”Sum(A1:A9)”);

wrb.addCell (formual);

添加超链接类单元格

WirtableHyperlink wrlink =

new WritableHyperlink(0,1,0,1,new URL(“www.emlog.net/fei”),”emlog”);

wrb.addHyperlink (wrlink);

// 添加图像

WritableImage wrimage=new WritableImage(1,5,10,10,new File(imageFilepath));

wrb.addImage (wrimage);

// 注意, API 中注明只支持 png 文件,然而我用其他格式的图片,通过将其后缘改为 png 也能放到 excel 文件中.果然,在查看其具体源代码时,发现作者只是检测了文件的后缀名,如果不对 给出警告,并没有从图像文件的具体格式进行检测.

当然,表格中的数据算是表格的核心部分,但是同时 API 也提供了大量的其他方法来丰富表格的显示.在此,大家具体在使用过程中进行运用就行.

// 最后,写完表格后,不要忘记进行写操作,也就是常说的保存

wrb.write()

wrb.close(); 保存完后关闭相应资源是一个合格的程序员应该做的.

接下来,我们就来讲述写文件的另一方面:更新文件.有时候,并不仅仅只是需要新写文件,可能需要对已有文件进行更新.这时候我们可以这么来实现.

Workbook wb= Workbook.getWorkbook(modifyFile);

WritableWorkbook wrb = Workbook.createWorkbook(modifyFile, wb);

以上就实现了得到一个已存在的文件的可修改副本.

// 得到第一个工作表

WritableSheet wrs = wrb.getSheet(0);

// 得到 A0 单元格

Cell cell = Wrs.getCell(0,0);

// 对单元格格式进行判断

If (cell.getType()==CellType.LABEL){

Label label=(Label) cell;

label.setString(“u r modified.”);

}//modify end

//save excel

wrb.write();

wb.close();

wrb.close();

    以上就简单的完成了一次 excel 文件的修改. API 中还提供了复制工作表,复制单元格等操作,大家可以通过查询 API 来了解其具体的用法. 我们可以从作者提供的包中得到很多关于如何使用API的示例.此处不献丑了 .jxl官文网站:http://www.andykhan.com/jexcelapi/index.html

<摘自>飞:jxl简析2 [ http://www.emlog.net/fei ]的更多相关文章

  1. <摘自>飞:jxl简析[ http://www.emlog.net/fei ]

    <摘自>飞:jxl简析:http://www.emlog.net/fei 最近,完成了一个网上报表系统,刚巧用到了一个 JAVA 操作 excel 表格的 API .闲来无事,就将其大概的 ...

  2. SpringMVC学习(一)——概念、流程图、源码简析

    学习资料:开涛的<跟我学SpringMVC.pdf> 众所周知,springMVC是比较常用的web框架,通常整合spring使用.这里抛开spring,单纯的对springMVC做一下总 ...

  3. 简析.NET Core 以及与 .NET Framework的关系

    简析.NET Core 以及与 .NET Framework的关系 一 .NET 的 Framework 们 二 .NET Core的到来 1. Runtime 2. Unified BCL 3. W ...

  4. 简析 .NET Core 构成体系

    简析 .NET Core 构成体系 Roslyn 编译器 RyuJIT 编译器 CoreCLR & CoreRT CoreFX(.NET Core Libraries) .NET Core 代 ...

  5. RecycleView + CardView 控件简析

    今天使用了V7包加入的RecycleView 和 CardView,写篇简析. 先上效果图: 原理图: 这是RecycleView的工作原理: 1.LayoutManager用来处理RecycleVi ...

  6. Java Android 注解(Annotation) 及几个常用开源项目注解原理简析

    不少开源库(ButterKnife.Retrofit.ActiveAndroid等等)都用到了注解的方式来简化代码提高开发效率. 本文简单介绍下 Annotation 示例.概念及作用.分类.自定义. ...

  7. PHP的错误报错级别设置原理简析

    原理简析 摘录php.ini文件的默认配置(php5.4): ; Common Values: ; E_ALL (Show all errors, warnings and notices inclu ...

  8. Android 启动过程简析

    首先我们先来看android构架图: android系统是构建在linux系统上面的. 所以android设备启动经历3个过程. Boot Loader,Linux Kernel & Andr ...

  9. Android RecycleView + CardView 控件简析

    今天使用了V7包加入的RecycleView 和 CardView,写篇简析. 先上效果图: 原理图: 这是RecycleView的工作原理: 1.LayoutManager用来处理RecycleVi ...

随机推荐

  1. VUE 安装项目

    注意:在cmd中执行的命令 1,前提是安装了node.js 查看 npm 版本号 2,创建项目路径 mkdir vue cd vue 3,安装vue-cli (脚手架) npm install -个v ...

  2. How to install the NVIDIA drivers on Fedora 32

    https://linuxconfig.org/how-to-install-the-nvidia-drivers-on-fedora-32 The NVIDIA Driver is a progra ...

  3. 写了多年代码,你会 StackOverflow 吗

    写了多年代码,你会 StackOverflow 吗 Intro 准备写一个傻逼代码的系列文章,怎么写 StackOverflow 的代码,怎么写死锁代码,怎么写一个把 CPU 跑满,怎么写一个 Out ...

  4. .Net Core中使用Grpc

    一.Grpc概述 gRPC 基于如下思想:定义一个服务, 指定其可以被远程调用的方法及其参数和返回类型.gRPC 默认使用protocol buffers作为接口定义语言,来描述服务接口和有效载荷消息 ...

  5. std::hash

    std::hash 由于C++11引入了哈希表数据结构std::unordered_map和std::unordered_set,所以对于基本类型也实现了标准的哈希函数std::hash,标准并没有规 ...

  6. Jmeter之参数化函数助手__CSVRead

    1.在Tool->函数对话框中选择__CSVRead,2处填写测试用例的文档地址(测试用例要以csv格式保存),3处是测试用例中参数的位置,第一栏参数的CSV文件列号填0,第二栏参数的CSV文件 ...

  7. ImageMagick实现图片的旋转/翻转/裁剪(ImageMagick6.9.10)

    一,imagemagick的安装 请参见: https://www.cnblogs.com/architectforest/p/12807514.html 说明:刘宏缔的架构森林是一个专注架构的博客, ...

  8. MySQL关于月份日期的操作

    #获取当前日期 SELECT CURDATE(); #获取本月最后一天 SELECT LAST_DAY(CURDATE()); #获取本月的第一天 SELECT DATE_ADD(CURDATE(), ...

  9. tp5伪静态--宝塔

    location / { if (!-e $request_filename) { rewrite ^(.*)$ /index.php?s=$1 last; break; } }

  10. eclipse中将java项目变成web项目

    今天,用Eclipse开发项目的时候,把一个Web项目导入到Eclipse里会变成了一个java工程,将无法在Tomcat中进行部署运行. 方法: 1.找到.project文件,找到里面的<na ...