网站导航网学 原创论文 原创专题 网站设计 最新系统 原创论文 论文降重 发表论文 论文发表 UI设计定制 论文答辩PPT格式排版 期刊发表 论文专题
返回网学首页
网学原创论文
最新论文 推荐专题 热门论文 论文专题
当前位置: 网学 > 交易代码 > Java精品代码 > 正文

java读取和写入EXCEL介绍

论文降重修改服务、格式排版等 获取论文 论文降重及排版 论文发表 相关服务

读取:
JXL(Java Excel API)是一个用来动态读写Excel文件的开源框架,利用它可以在任何支持Java的操作系统上动态读写Excel文件。JXL的主页是:http://www.andykhan.com/jexcelapi/,可以在这里下载到它的最新的版本。
你可以分别通过如下命令
java -jar jxl.jar -xml test.xls
java -jar jxl.jar -cvs test.xls
以xml和cvs格式查看test.xls,这是因为JXL作者实现了一个用来演示的jxl.demo.Demo的类。

当然我们使用JXL主要是用它来动态读写Excel文件。现在就来看看JXL在对Excel的读和写上都提供了那些支持。
先来看看Excel文件中都有写上面对象
1 文件对象 2工作簿对象 3 单元格对象。
相应的在JXL中就有Workbook,Sheet ,Cell 。通过这三个对象我们就可以实现Excel文件的读取工作。
我们先想想一下读取步骤,不管是什么样的Excel操作框架必定都要经历
1选取Excel文件,2选择工作簿,3选择Cell,4读取信息。
那么现在就可以看看JXL中这四步骤如何体现:
//通过Workbook的静态方法getWorkbook选取Excel文件
Workbook workbook = Workbook.getWorkbook(new File("myfile.xls"));

//通过Workbook的getSheet方法选择第一个工作簿(从0开始)
Sheet sheet = workbook.getSheet(0);

//通过Sheet方法的getCell方法选择位置为C2的单元格(两个参数都从0开始)
Cell c2 = sheet.getCell(2,1); //第一个是列,第二个是行

//通过Cell的getContents方法把单元格中的信息以字符的形式读取出来
String stringc2 = c2.getContents();

可以看到正是刚才所说的四个步骤。

我们都知道Excel单元格是有格式的,那么这些信息如何取得。
Cell提供了一个getType方法能够返回单元格的类型信息,同时JXL提供了一个CellType类用来预设Excel中的类型信息,而且JXL提供了一些Cell类的子类用来分别用来表示各种类型的单元格,如LabelCell,NumberCell,DateCell分别表示字符、数值、日期类型的单元格。所以我们可以这样写:
if (c2.getType() == CellType.NUMBER)
{
  NumberCell nc = (NumberCell) c2;
  numberb2 = nc.getValue();
}

最后不要忘记关闭workbook以释放资源:
workbook.close();
现在总结一下:三个对象,四个步骤,注意格式。就可以轻松的从Excel文件中读取数据。

例:

Java代码
String str = new String[5000];  
File file = new File("D:\\1.xls");  
Workbook workbook = Workbook.getWorkbook(file);  
Sheet sheet = workbook.getSheet(0);  
               Cell cell = null;  
for(int i=0;i<sheet.getRows();i++){  
cell = sheet.getCell(0,i);  //第一个是列,第二个是行   //由于需求只读取第一列的  
str[i] = cell.getContents();  
}  
workbook.close(); 

                String str = new String[5000];
                File file = new File("D:\\1.xls");
                Workbook workbook = Workbook.getWorkbook(file);
                Sheet sheet = workbook.getSheet(0);
                        Cell cell = null;
                for(int i=0;i<sheet.getRows();i++){
                 cell = sheet.getCell(0,i);  //第一个是列,第二个是行   //由于需求只读取第一列的
                 str[i] = cell.getContents();
                }
                workbook.close();

写入:

1、建立一个xls文件

OutputStream os=new FileOutputStream("c:\\test.xls");

2、建立工作文件

WritableWorkbook wwb = Workbook.createWorkbook(os);

3、如果这个文件已经存在,那么我们可以在这个文件里面加入一个sheet为了和以前的数据进行分开;
jxl.write.WritableSheet ws = wwb.createSheet("Sheet 1", 0);
在createSheet方法里前面的参数是sheet名,后面是要操作的sheet号

4、写入数据

(1)最简单的字符型数据

Label label = new Label(0, 0, "This is a Label cell",wcfF);
ws.addCell(label);
在Label()方法里面有三个参数
第一个是代表列数,
第二是代表行数,
第三个代表要写入的内容
第四个是可选项,是输入这个label里面的样式
然后通过写sheet的方法addCell()把内容写进sheet里面。

字体样式:

WritableFont wf = new WritableFont(WritableFont.TIMES, 18, WritableFont.BOLD, true);
WritableFont()方法里参数说明:
这个方法算是一个容器,可以放进去好多属性
第一个: TIMES是字体大小,他写的是18
第二个: BOLD是判断是否为斜体,选择true时为斜体
第三个: ARIAL
第四个: UnderlineStyle.NO_UNDERLINE 下划线
第五个: jxl.format.Colour.RED 字体颜色是红色的

WritableCellFormat wcfF = new WritableCellFormat(wf);

(2)添加带有formatting的Number对象
NumberFormat nf = new NumberFormat("#.##");

(3)添加Number对象

(3.1)显示number对象数据的格式

NumberFormat nf = new NumberFormat("#.##");
WritableCellFormat wcfN = new WritableCellFormat(nf);
Number labelNF = new Number(1,1,3.1415926,wcfN);
ws.addCell(labelNF);
Number()方法参数说明:
前两上表示输入的位置
第三个表示输入的内容

(4)添加Boolean对象

Boolean labelB = new Boolean(0,2,false);
ws.addCell(labelB);

(5)添加DateTime对象

DateTime labelDT = new DateTime(0,3,new java.util.Date());
ws.addCell(labelDT);
DateTime()方法的参数说明
前两个表示输入的位置

第三个表示输入的当前时间

(6)添加带有formatting的DateFormat对象

这个显示当前时间的所有信息,包括年月日小时分秒
DateFormat df = new DateFormat("dd MM yyyy hh:mm:ss");
WritableCellFormat wcfDF = new WritableCellFormat(df);
DateTime labelDTF = new DateTime(1,3,new java.util.Date(),wcfDF);
ws.addCell(labelDTF);

(7)添加带有字体颜色Formatting的对象

WritableFont wfc = new WritableFont(WritableFont.ARIAL, 10, WritableFont.NO_BOLD, false,UnderlineStyle.NO_UNDERLINE, Colour.RED);
WritableCellFormat wcfFC = new WritableCellFormat(wfc);
import="jxl.format.*
WritableFont wfc = new WritableFont(WritableFont.ARIAL,20,WritableFont.BOLD,false,UnderlineStyle.NO_UNDERLINE,jxl.format.Colour.GREEN);

(8)设置单元格样式

WritableCellFormat wcfFC = new WritableCellFormat(wfc);
wcfFC.setBackGround(Colour.RED);//设置单元格的颜色为红色
wcfFC = new Label(6,0,"I love china",wcfFC);
例:

Java代码
OutputStream os=new FileOutputStream("D:\\2.xls");  
WritableWorkbook wwb = Workbook.createWorkbook(os);  
jxl.write.WritableSheet ws = wwb.createSheet("Sheet 1", 0);  
 
for(int i=0;phone[i]!=null;i++){   //phone为一个数组  
    Label label = new Label(0, i, phone[i]);  //由于需求只在第一列输出  
    ws.addCell(label);                
}  
wwb.write();  
wwb.close();  
os.close();

TAG: Java教程java教程JAVA教程




点击下载系统:http://www.myeducs.cn/chaxun/index.html?go=java读取和写入EXCEL介绍&aa=%CB%D1%CB%F7%C2%DB%CE%C4
  • 上一篇资讯: JAVA反射机制介绍
  • 下一篇资讯: 初学java,javac怎么用
  • 设为首页 | 加入收藏 | 网学首页 | 原创论文 | 计算机原创
    版权所有 网学网 [Myeducs.cn] 您电脑的分辨率是 像素
    Copyright 2008-2020 myeducs.Cn www.myeducs.Cn All Rights Reserved 湘ICP备09003080号 常年法律顾问:王律师