zoukankan      html  css  js  c++  java
  • java操作excel总结---poi

    前不久做过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;
        }

  • 相关阅读:
    Java [leetcode 33]Search in Rotated Sorted Array
    JAVA方法和本地方法(转载)
    Java集合框架
    常用排序算法
    Java [leetcode 32]Longest Valid Parentheses
    四大组件的生命周期
    Android Service即四大组件总结
    Java [leetcode 31]Next Permutation
    android 组件设置屏幕大小
    MenuInflater用法
  • 原文地址:https://www.cnblogs.com/lcngu/p/5021937.html
Copyright © 2011-2022 走看看