1.分析

一个excel文件能够有多页,每页excel中能够有多行,每行中能够有多列。用面向对象的思想能够把一行中的某列看作是一个String对象,一行看作是一个包括多个列的对象。一页是包括多行的对面,一个excle文件就是包括多页的对象

2.行对象的设计

package com.zhaochao.utils;

import java.util.List;
/**
*
* excel的行对象
*
* @author 赵超
*
*/
public class ExcelRow {
private List<String> colData; //当前行的全部列数据
public Integer getCols() {
return colData.size();
}
public List<String> getColData() {
return colData;
}
public void setColData(List<String> colData2) {
this.colData = colData2;
} }

2.页对象的设计

package com.zhaochao.utils;

import java.util.List;
/**
*
* Excel页对象
*
* @author 赵超
*
*/
public class ExcelPage {
private List<ExcelRow> rowData; //当页excel的全部行数据
public Integer getRows() {
return rowData.size();
}
public List<ExcelRow> getRowData() {
return rowData;
}
public void setRowData(List<ExcelRow> rowData) {
this.rowData = rowData;
} }

3.excel对象的设计

package com.zhaochao.utils;

import java.util.List;
/**
*
* Excel模型类
*
*
* @author 赵超
*
*/
public class ExcelModel {
private List<ExcelPage> pageData; //Excel每页的数据
public Integer getPages() {
return pageData.size();
}
public List<ExcelPage> getPageData() {
return pageData;
}
public void setPageData(List<ExcelPage> pageData) {
this.pageData = pageData;
}
}

4.excel读写工具类的设计

package com.zhaochao.utils;

import java.io.File;
import java.io.FileInputStream;
import java.io.InputStream;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.ArrayList;
import java.util.List; import jxl.Workbook;
import jxl.write.Label;
import jxl.write.WritableSheet;
import jxl.write.WritableWorkbook;
/**
*
* @author 操作excel工具类
*
*/
public class ExcelUtil { public static void main(String [] args){ //testWriteExcel();
testReadExcel();
} public static void testReadExcel(){
//String urlStr="http://baaifile.b0.upaiyun.com/uploadfile/2014/10/25/201410251038347176.xls";
//String urlStr="C:\\Users\\Administrator\\Desktop\\privateCoupon.xls";
String urlStr="c://user.xls";
ExcelModel model= ExcelUtil.ReadExcel(urlStr);
int pageSize=0;
for(ExcelPage page: model.getPageData()){
for(ExcelRow row:page.getRowData()){
for(String col:row.getColData()){
System.out.print(col+" ");
}
System.out.println();
}
System.out.println("======总共"+model.getPages()+"页=====第"+(++pageSize)+"页====================");
}
}
public static void testWriteExcel(){
String fileName="c://user.xls";
//设置两列数据
List<String> cols=new ArrayList<String>();
cols.add("admin");
cols.add("123");
//设置行数据
ExcelRow row=new ExcelRow();
row.setColData(cols);
List<ExcelRow> rows=new ArrayList<ExcelRow>();
rows.add(row);
rows.add(row);
//设置页数据
ExcelPage page=new ExcelPage();
page.setRowData(rows);
List<ExcelPage> pages=new ArrayList<ExcelPage>();
pages.add(page);
pages.add(page);
//设置excleModel
ExcelModel model=new ExcelModel();
model.setPageData(pages);
writeExcel(fileName,model);
} /**
* 在线解析Excel
*
* @param urlStr 能够是http://开头的url,也能够是文件路径
*
* @return 返回ExcelMode
*/
private static ExcelModel ReadExcel(String urlStr) {
ExcelModel excle= new ExcelModel();
try {
InputStream is=null;
if(urlStr.startsWith("http://")){
URL url=new URL(urlStr);
HttpURLConnection httpUrl=(HttpURLConnection) url.openConnection();
httpUrl.connect();
is = httpUrl.getInputStream();
}else{
File f=new File(urlStr);
if(f.exists()){
is= new FileInputStream(f) ;
}else{
throw new Exception("文件不存");
}
}
Workbook wb = Workbook.getWorkbook(is);
jxl.Sheet [] sheet =wb.getSheets();
List<ExcelPage> pageDate=new ArrayList<ExcelPage>();
for(int s=0;s<sheet.length;s++){
ExcelPage page=new ExcelPage();
List<ExcelRow> rows=new ArrayList<ExcelRow>();
for(int i=0;i<sheet[s].getRows();i++){
ExcelRow row=new ExcelRow();
List<String> colData=new ArrayList<String>();
for(int j=0;j<sheet[s].getColumns();j++){
colData.add(sheet[s].getCell(j, i).getContents());
}
row.setColData(colData);
rows.add(row);
}
page.setRowData(rows);
pageDate.add(page);
}
excle.setPageData(pageDate);
wb.close();
is.close();
} catch (Exception e) {
e.printStackTrace();
}
return excle;
}
/**
*
* @param fileName 要写入文件的路径
* @param excel 要写入文件的数据
*/ private static void writeExcel(String fileName,ExcelModel excel) {
try {
WritableWorkbook book = Workbook.createWorkbook(new File(fileName));
for(int page=0;page<excel.getPages();page++){
WritableSheet sheet = book.createSheet("第"+page+"页", 0);
// 在label对象的构造方法中指名单元格位置是第一列。第一行(0,0)
// 以及单元格内容为test
for(int row=0;row<excel.getPageData().get(page).getRows();row++){
for(int col=0;col<excel.getPageData().get(page).getRowData().get(row).getCols();col++){
Label label = new Label(col,row ,excel.getPageData().get(page).getRowData().get(row).getColData().get(col));
// 将定义好的单元格加入到工作表中
sheet.addCell(label);
}
} }
// 写入数据并关闭文件
book.write();
book.close();
System.out.println("生成excel文件成功");
} catch (Exception e) {
e.printStackTrace();
}
} }

5.写測试

watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvd2h6aGFvY2hhbw==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast" alt="">

6.读測试




JXL.jar简单封装Excel读写操作的更多相关文章

  1. Java学习---Excel读写操作

    1.1.1. 简介 Apache POI 使用Apache POI 完成Excel读写操作 Apache POI 是用Java编写的免费开源的跨平台的 Java API,Apache POI提供API ...

  2. NX二次开发-基于MFC界面的NX对Excel读写操作(OLE方式(COM组件))

    NX二次开发API里没有对EXCAL读写操作的相关函数,市面上有很多种方法去实现,比如UFUN调KF,ODBC,OLE(COM组件)等等.这里我是用的OLE(COM组件)方式去做的,这种在VC上创建的 ...

  3. NX二次开发-基于NX开发向导模板的NX对Excel读写操作(OLE方式(COM组件))

    在看这个博客前,请读者先去完整看完:NX二次开发-基于MFC界面的NX对Excel读写操作(OLE方式(COM组件))https://ufun-nxopen.blog.csdn.net/article ...

  4. Java使用jxl.jar包写Excel文件的最适合列宽问题基本实现

    以前用jxl.jar包,读写过Excel文件.也没有注意最适合列宽的问题,但是jxl.jar没有提供最适合列宽的功能,上次用到写了一下,可以基本实现最适合列宽. 注意,这个只是基本可以实现,基本针对中 ...

  5. 轻松完成excel读写操作- 基于POI的框架BingExcel的使用(1)

    Bingexcel User Guide 使用maven进行项目开发目前项目的maven仓库是在github上,浏览地址为 https://github.com/bingyulei007/mvn-re ...

  6. 【Python】excel读写操作 xlrd & xlwt

    xlrd ■ xlrd xlrd模块用于读取excel文件内容 基本用法: workbook = xlrd.open_workbook('文件路径') workbook.sheet_names() # ...

  7. 轻松完成excel读写操作- 基于POI的框架BingExcel的使用(2)

    在进行 类转换时候,系统默认注册了一些转换器,当然你也可以自定局部或者全局的转换器.下面进行具体使用说明  java类说明 对应的java实体类,其属性必须要有__@CellConfig__注解,此注 ...

  8. Excel 读写操作

    读 import xlrd from xlrd.book import Book from xlrd.sheet import Sheet from xlrd.sheet import Cell wo ...

  9. 78、excel的读写操作

    本篇主要是用python来自动生成excel数据文件也就是简单的excel读写操作.python读写excel文件主要是第三方模块库xlrd.xlwt. 本篇导航: 写excel 读excel 一.写 ...

随机推荐

  1. dmesg---检查和控制内核的环形缓冲区

    dmesg命令被用于检查和控制内核的环形缓冲区.kernel会将开机信息存储在ring buffer中.您若是开机时来不及查看信息,可利用dmesg来查看.开机信息保存在/var/log/dmesg文 ...

  2. Zookeeper入门-Java版本HelloWorld例子

    上一篇介绍了,Zookeeper的基本概念,怎么启动,怎么解决可能遇到的几个问题.本篇,根据网上代码,整理了一个例子,Zookeeper的HelloWorld. 下面这个代码,还是比较简单的,核心类就 ...

  3. Java基础学习总结(10)——static关键字

    一.static关键字 原来一个类里面的成员变量,每new一个对象,这个对象就有一份自己的成员变量,因为这些成员变量都不是静态成员变量.对于static成员变量来说,这个成员变量只有一份,而且这一份是 ...

  4. 洛谷——P1966 火柴排队

    https://www.luogu.org/problem/show?pid=1966 题目描述 涵涵有两盒火柴,每盒装有 n 根火柴,每根火柴都有一个高度. 现在将每盒中的火柴各自排成一列, 同一列 ...

  5. centos同步网络北京时间

    sudo yum -y install ntpdate ntp sudo ntpdate time.windows.com sudo hwclock -w

  6. Spring MVC 注解式

    1.注解式控制器简介 一.Spring2.5之前,我们都是通过实现Controller接口或其实现来定义我们的处理器类.已经@Deprecated.   二.Spring2.5引入注解式处理器支持,通 ...

  7. Oracle修改表空间自增长

    下面列出详细过程: 1.通过sql plus 命令登录数据库. 在命令行下输入sqlplus “登录用户名/口令 as 登录类型”就可以登录,系统内建的用户名常用的是sys,密码是在安装oracle过 ...

  8. Lightroom 学习笔记

    16.8.28  白平衡:      夕阳照片,色温高大

  9. 概率编程:《贝叶斯方法概率编程与贝叶斯推断》中文PDF+英文PDF+代码

    贝叶斯推理的方法非常自然和极其强大.然而,大多数图书讨论贝叶斯推理,依赖于非常复杂的数学分析和人工的例子,使没有强大数学背景的人无法接触.<贝叶斯方法概率编程与贝叶斯推断>从编程.计算的角 ...

  10. mysql 查看单个表每个索引的大小

    /*单个表每个索引的大小*/ SELECT sum(stat_value) pages, table_name part, index_name, concat(,),'M',' rows') * @ ...