`

Java 操作Excel

 
阅读更多
前不久做过Excel的导入导出功能,其主要的难点是java如何操作Excel文档。现在就来介绍一下利用Apache的poi如何操作Excel。

1.准备工作:导入Apache POI的相关jar包,POI的Web站点是: http://poi.apache.org/。

2.创建Excel文档:

示例1将演示如何利用Jakarta POI API 创建Excel 文档。

示例1程序如下:
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFCell;
import java.io.FileOutputStream;
public class CreateExcel {

/** Excel 文件要存放的位置,假定在E盘Test目录下*/

public static String outputFile="E:/Test/ model.xls";
public static void main(String args[]){

 try{

  // 创建新的Excel 工作簿
  HSSFWorkbook workbook = new HSSFWorkbook();

  // 在Excel工作簿中建一工作表,其名为缺省值
  // 如要新建一名为"model"的工作表,其语句为:
  // HSSFSheet sheet = workbook.createSheet("model");

  HSSFSheet sheet = workbook.createSheet();

  // 在索引0的位置创建行(最顶端的行)
  HSSFRow row = sheet.createRow((short)0);

  //在索引0的位置创建单元格(左上端)
  HSSFCell cell = row.createCell((short) 0);


  // 定义单元格为字符串类型
  cell.setCellType(HSSFCell.CELL_TYPE_STRING);


  // 在单元格中输入一些内容
  cell.setCellValue("增加值");


  // 新建一输出文件流
  FileOutputStream fileOut = new FileOutputStream(outputFile);


  // 把相应的Excel 工作簿存盘
  workbook.write(fileOut);
  fileOut.flush();


  // 操作结束,关闭文件
  fileOut.close();
  System.out.println("文件生成...");

 }catch(Exception e) {
  System.out.println("已运行 xlCreate() : " + e );
 }
}
}



2.读取Excel文档中的数据:

示例2将演示如何读取Excel文档中的数据。假定在E盘Test目录下有一个文件名为model.xls的Excel文件。

示例2程序如下:

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFCell;
import java.io.FileInputStream;
public class ReadExcel {


 /** Excel文件的存放位置。注意是正斜线*/
 public static String filePath="E:/Test/ model.xls";
 public static void main(String args[]){
 try{
  // 创建对Excel工作簿文件的引用
  HSSFWorkbook workbook = new HSSFWorkbook(new FileInputStream(filePath));


  // 创建对工作表的引用。
  // 本例是按名引用(让我们假定那张表有着缺省名"Sheet1")
  HSSFSheet sheet = workbook.getSheet("Sheet1");


  // 也可用getSheetAt(int index)按索引引用,
  // 在Excel文档中,第一张工作表的缺省索引是0,
  // 其语句为:HSSFSheet sheet = workbook.getSheetAt(0);


  // 读取左上端单元
  HSSFRow row = sheet.getRow(0);
  HSSFCell cell = row.getCell((short)0);


  // 输出单元内容,cell.getStringCellValue()就是取所在单元的值
  System.out.println("左上端单元是: " + cell.getStringCellValue());
 }catch(Exception e) {
  System.out.println("已运行xlRead() : " + e );
 }
}
}



3. 设置单元格格式:

在这里,将只介绍一些和格式设置有关的语句,我们假定workbook就是对一个工作簿的引用。在Java中,第一步要做的就是创建和设置字体和单元格的格式,然后再应用这些格式:



3.1 创建字体,设置其为红色、粗体:
HSSFFont font = workbook.createFont();
font.setColor(HSSFFont.COLOR_RED);
font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);



3.2 创建格式
HSSFCellStyle cellStyle= workbook.createCellStyle();
cellStyle.setFont(font);



3.3应用格式

HSSFCell cell = row.createCell((short) 0);
cell.setCellStyle(cellStyle);
cell.setCellType(HSSFCell.CELL_TYPE_STRING);
cell.setCellValue("标题 ");


4.POI中Excel文件单元格的类型
在读取每一个单元格的值的时候,通过getCellType方法获得当前单元格的类型,在Excel中单元格有6种类型,如下所示。
1)CELL_TYPE_BLANK :空值
2)CELL_TYPE_BOOLEAN :布尔型
3)CELL_TYPE_ERROR : 错误
4)CELL_TYPE_FORMULA :公式型
5)CELL_TYPE_STRING:字符串型
6)CELL_TYPE_NUMERIC:数值型
如果单元格的Type为CELL_TYPE_NUMERIC时,还需要进一步判断该单元格的数据格式,因为它有可能是Date类型,在Excel中的Date类型也是以Double类型的数字存储的。Excel中的Date表示当前时间与1900年1月1日相隔的天数,所以需要调用HSSFDateUtil的isCellDateFormatted方法,判断该单元格的数据格式是否是Excel Date类型。如果是,则调用getDateCellValue方法,返回一个Java类型的Date。

因此读取Excel中单元格中的数据时,得判断单元格格式类型,这是我写的,参考一下:
private Object getCellData(Cell cell, FormulaEvaluator formula) {
    if(cell == null) {
        return null;
    }
    switch (cell.getCellType()) {
    case Cell.CELL_TYPE_STRING:
        return cell.getRichStringCellValue().getString();
    case Cell.CELL_TYPE_NUMERIC:
        if (DateUtil.isCellDateFormatted(cell)) {
            return cell.getDateCellValue();
        } else {
            return cell.getNumericCellValue();
        }
    case Cell.CELL_TYPE_BOOLEAN:
        return cell.getBooleanCellValue();
    case Cell.CELL_TYPE_FORMULA:
        return formula.evaluate(cell).getNumberValue();
    default:
        return null;
    }
}


9
1
分享到:
评论
2 楼 归来朝歌 2015-06-11  
不错,以后可能用得上
1 楼 luhantu 2015-06-10  
不错!学习了

相关推荐

    java操作excel表格的工具类库

    通过java操作excel表格的工具类库 用法简介 ● 支持Excel 95-2000的所有版本 ● 生成Excel 2000标准格式 ● 支持字体、数字、日期操作 ● 能够修饰单元格属性 ● 支持图像和图表 应该说以上功能已经能够大致满足我们...

    Java 操作Excel和Word的所有资料

    Java 操作Excel和Word的所有资料Java 操作Excel和Word的所有资料Java 操作Excel和Word的所有资料Java 操作Excel和Word的所有资料Java 操作Excel和Word的所有资料Java 操作Excel和Word的所有资料Java 操作Excel和Word...

    Java操作Excel

    Java操作Excel

    java操作excel的实例

    java操作excel的实例java操作excel的实例java操作excel的实例java操作excel的实例

    java操作excel(包括读取数据和写入数据)

    java操作excel(包括读取数据和写入数据)亲自测试成功 可以直接使用 控制台输出如下: 工作表名称:Sheet1 姓名 年龄 张三 18 李四 19 王五 20 工作表名称:Sheet2 工作表名称:Sheet3

    Java操作Excel表格

    通过Java操作Excel表格,包括上传Excel文件、Action类解析Excel、以及导出数据到Excel表格。

    Java操作Excel详解

    详细介绍Java操作Excel,包括对Excel的读、写、更新等操作,并附加例子.

    java操作excel读写

    java操作excel读写,可以根据自己的需要灵活修改。导入导出excel

    Java操作Excel的开源库

    Java操作Excel的开源库,JExcel,很好用的说

    java操作Excel文件

    java操作Excel文件java操作Excel文件java操作Excel文件java操作Excel文件java操作Excel文件java操作Excel文件java操作Excel文件

    最全最实用的Java操作Excel教程

    非常全面的非常实用的java操作excel的教程

    java操作excel

    java操作excel源码,一个简单的demo。帮助初学者入门。

    用java操作Excel的一中非常好的工具

    这是最新的jxl,里面有编译好的jxl类和jxl的帮助,是用java操作Excel的一中非常好的方法。非常方便!!!是到现在为止的最新版本!

    jxl Java操作Excel

    java操作Excel java操作Excel java操作Excel

    java操作excel的jar包

    java操作excel的jar包,包括三个jar包,java加载这三个jar包即可实现对excel的创建,读取,写入数据等操作。

    java操作Excel全过程带源码

    java操作Excel全过程带源码,找了好久才找到.

    Java操作Excel表两种方式

    Java操作Excel表的两种方式,具体教程可以网上查看,这里只有jar包

    java操作excel代码[文].pdf

    java操作excel代码[文].pdf

    java操作excel的工具包

    java操作excel的工具包,我收集的。maven上似乎下不到,是某个半开源的模板里的。我写了几个例子,不熟悉的可以去我的博客下留言。

    java操作excel的工具类

    java操作excel的工具类,有处理excel的方法。 好资源大家一起分享。如果急需用,但是有下载积分的话,关注我,留言我,就OK了。 希望大家关注的我的CSDN。 我的昵称:今升·小博 地址:...

Global site tag (gtag.js) - Google Analytics