`
齐晓威_518
  • 浏览: 618019 次
  • 性别: Icon_minigender_1
  • 来自: 郑州
社区版块
存档分类
最新评论

POI操作Excel常用方法总结

 
阅读更多

一、POI简介

      Apache POIApache软件基金会的开放源码函式库,POI提供APIJava程序对Microsoft Office格式档案读和写的功能。

二、HSSF概况

      HSSFHorrible SpreadSheet Format的缩写,通过HSSF,你可以用纯Java代码来读取、写入、修改Excel文件。HSSF为读取操作提供了两类APIusermodel eventusermodel,即用户模型事件-用户模型

三、 POI EXCEL文档结构类

      HSSFWorkbook           excel文档对象

      HSSFSheet                 excelsheet HSSFRow excel的行

      HSSFCell                    excel的单元格 HSSFFont excel字体

      HSSFName                 名称

     HSSFDataFormat        日期格式

      HSSFHeader               sheet

      HSSFFooter                sheet

      HSSFCellStyle             cell样式

      HSSFDateUtil               日期

      HSSFPrintSetup           打印

      HSSFErrorConstants    错误信息表

四、EXCEL常用操作方法 

      1 得到Excel常用对象

      POIFSFileSystem fs = new POIFSFileSystem(new FileInputStream("d:/test.xls")); 
      // 得到Excel工作簿对象 
      HSSFWorkbook wb = new HSSFWorkbook(fs);
      // 得到Excel工作表对象 
      HSSFSheet sheet = wb.getSheetAt(0); 
      // 得到Excel工作表的行 
      HSSFRow row = sheet.getRow(i);
      // 得到Excel工作表指定行的单元格 
      HSSFCell cell = row.getCell((short) j);
      // 得到单元格样式
      cellStyle = cell.getCellStyle();

      2建立Excel常用对象

      // 创建Excel工作簿对象      
      HSSFWorkbook wb = new HSSFWorkbook();
      // 创建Excel工作表对象
      HSSFSheet sheet = wb.createSheet("new sheet");
      // 创建Excel工作表的行
      HSSFRow row = sheet.createRow((short)0);
      // 创建单元格样式
      cellStyle = wb.createCellStyle();
      // 创建Excel工作表指定行的单元格
      row.createCell((short)0).setCellStyle(cellStyle);
      // 设置Excel工作表的值
      row.createCell((short)0).setCellValue(1);

   3、设置sheet名称和单元格内容

       wb.setSheetName(1, "第一张工作表",HSSFCell.ENCODING_UTF_16);        
       cell.setEncoding((short) 1);    
       cell.setCellValue("单元格内容");

   4、取得sheet的数目

      wb.getNumberOfSheets();

   5index取得sheet对象

       HSSFSheet sheet = wb.getSheetAt(0); 

   6、取得有效的行数

       int rowcount = sheet.getLastRowNum(); 

      7、取得一行的有效单元格个数

       row.getLastCellNum();

      8、单元格值类型读写

     // 设置单元格为STRING类型
     cell.setCellType(HSSFCell.CELL_TYPE_STRING);
     // 读取为数值类型的单元格内容
     cell.getNumericCellValue();

    9、设置列宽、行高 

     sheet.setColumnWidth((short)column,(short)width);    
     row.setHeight((short)height);

    10、添加区域,合并单元格 

     // 合并从第rowFromcolumnFrom列到rowTocolumnTo的区域
     Region region = new Region((short)rowFrom,(short)columnFrom,(short)rowTo,(short)columnTo);
     sheet.addMergedRegion(region);
     // 得到所有区域
     sheet.getNumMergedRegions();

    11、保存Excel文件

     FileOutputStream fileOut = new FileOutputStream(path); 
     wb.write(fileOut); 

    12、根据单元格不同属性返回字符串数值
   public String getCellStringValue(HSSFCell cell) {    
        String cellValue = "";    
        switch (cell.getCellType()) {    
        case HSSFCell.CELL_TYPE_STRING:   //
字符串类型
            cellValue = cell.getStringCellValue();    
            if(cellValue.trim().equals("")||cellValue.trim().length()<=0)    
                cellValue=" ";    
            break;    
        case HSSFCell.CELL_TYPE_NUMERIC: //
数值类型
            cellValue = String.valueOf(cell.getNumericCellValue());    
            break;    
        case HSSFCell.CELL_TYPE_FORMULA: //
公式
            cell.setCellType(HSSFCell.CELL_TYPE_NUMERIC);    
            cellValue = String.valueOf(cell.getNumericCellValue());    
            break;    
        case HSSFCell.CELL_TYPE_BLANK:    
            cellValue=" ";    
            break;    
        case HSSFCell.CELL_TYPE_BOOLEAN:    
            break;    
        case HSSFCell.CELL_TYPE_ERROR:    
            break;    
        default:    
            break;    
        }    
        return cellValue;    
    }

    13、常用单元格边框格式

    HSSFCellStyle style = wb.createCellStyle();    
    style.setBorderBottom(HSSFCellStyle.BORDER_DOTTED);  //
下边框     
    style.setBorderLeft(HSSFCellStyle.BORDER_DOTTED);      //
左边框     
    style.setBorderRight(HSSFCellStyle.BORDER_THIN);        //
右边框     
    style.setBorderTop(HSSFCellStyle.BORDER_THIN);          //
上边框  

    14、设置字体和内容位置

    HSSFFont f = wb.createFont();    
    f.setFontHeightInPoints((short) 11);                                     //
字号    
    f.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);               //
加粗    
    style.setFont(f);    
    style.setAlignment(HSSFCellStyle.ALIGN_CENTER);                 //
左右居中    
    style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER); //
上下居中    
    style.setRotation(short rotation);                                        //
单元格内容的旋转的角度    
    HSSFDataFormat df = wb.createDataFormat();    
    style1.setDataFormat(df.getFormat("0.00%"));                    //
设置单元格数据格式    
    cell.setCellFormula(string);                                                 //
给单元格设公式    
    style.setRotation(short rotation);                                       //
单元格内容的旋转的角度 

  15、插入图片

    // 先把读进来的图片放到一个ByteArrayOutputStream,以便产生ByteArray    
    ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();    
    BufferedImage bufferImg = ImageIO.read(new File("ok.jpg"));    
    ImageIO.write(bufferImg,"jpg",byteArrayOut);    
    //
读进一个excel模版    
    FileInputStream fos = new FileInputStream(filePathName+"/stencil.xlt");     
    fs = new POIFSFileSystem(fos);    
    //
创建一个工作薄    
    HSSFWorkbook wb = new HSSFWorkbook(fs);    
    HSSFSheet sheet = wb.getSheetAt(0);    
    HSSFPatriarch patriarch = sheet.createDrawingPatriarch();    
    HSSFClientAnchor anchor = new HSSFClientAnchor(0,0,1023,255,(short) 0,0,(short)10,10);
    patriarch.createPicture(anchor, wb.addPicture(byteArrayOut.toByteArray(), HSSFWorkbook.PICTURE_TYPE_JPEG));

    16、调整工作表位置

    HSSFWorkbook wb = new HSSFWorkbook();   
    HSSFSheet sheet = wb.createSheet("format sheet");   
    HSSFPrintSetup ps = sheet.getPrintSetup();   
    sheet.setAutobreaks(true);   
    ps.setFitHeight((short)1);   
    ps.setFitWidth((short)1); 

   17、设置打印区域

    HSSFSheet sheet = wb.createSheet("Sheet1");   
    wb.setPrintArea(0, "$A$1:$C$2");  

 

   18、标注脚注

    HSSFSheet sheet = wb.createSheet("format sheet");   
    HSSFFooter footer = sheet.getFooter()   
    footer.setRight( "Page " + HSSFFooter.page() + " of " + HSSFFooter.numPages() ); 

   19、在工作单中清空行数据,调整行位置

    HSSFWorkbook wb = new HSSFWorkbook();   
    HSSFSheet sheet = wb.createSheet("row sheet");   
    // Create various cells and rows for spreadsheet.   
    // Shift rows 6 - 11 on the spreadsheet to the top (rows 0 - 5)   
    sheet.shiftRows(5, 10, -5);  

   20、选中指定的工作表

   HSSFSheet sheet = wb.createSheet("row sheet");   
   heet.setSelected(true);

   21、工作表的放大缩小   

  HSSFSheet sheet1 = wb.createSheet("new sheet");   
   sheet1.setZoom(1,2);   // 50 percent magnification  

   22、头注和脚注

   HSSFSheet sheet = wb.createSheet("new sheet");   
   HSSFHeader header = sheet.getHeader();   
   header.setCenter("Center Header");   
   header.setLeft("Left Header");   
   header.setRight(HSSFHeader.font("Stencil-Normal", "Italic") + HSSFHeader.fontSize((short) 16) + "Right w/ Stencil-Normal Italic font and size 16");

 

    23、自定义颜色 

   HSSFCellStyle style = wb.createCellStyle();   
   style.setFillForegroundColor(HSSFColor.LIME.index);   
   style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);   
   HSSFFont font = wb.createFont();   
   font.setColor(HSSFColor.RED.index);   
   style.setFont(font);   
   cell.setCellStyle(style);

   24、填充和颜色设置

   HSSFCellStyle style = wb.createCellStyle();   
   style.setFillBackgroundColor(HSSFColor.AQUA.index);   
   style.setFillPattern(HSSFCellStyle.BIG_SPOTS);   
   HSSFCell cell = row.createCell((short) 1);   
   cell.setCellValue("X");   
   style = wb.createCellStyle();   
   style.setFillForegroundColor(HSSFColor.ORANGE.index);   
   style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);   
   cell.setCellStyle(style); 

   25、强行刷新单元格公式

   HSSFFormulaEvaluator eval=new HSSFFormulaEvaluator((HSSFWorkbook) wb);  
   private static void updateFormula(Workbook wb,Sheet s,int row){   
        Row r=s.getRow(row);   
        Cell c=null;   
        FormulaEcaluator eval=null;   
        if(wb instanceof HSSFWorkbook)   
            eval=new HSSFFormulaEvaluator((HSSFWorkbook) wb);   
        else if(wb instanceof XSSFWorkbook)   
            eval=new XSSFFormulaEvaluator((XSSFWorkbook) wb);   
        for(int i=r.getFirstCellNum();i<r.getLastCellNum();i++){   
            c=r.getCell(i);   
            if(c.getCellType()==Cell.CELL_TYPE_FORMULA)   
                eval.evaluateFormulaCell(c);   
        }   

    }

说明:FormulaEvaluator提供了evaluateFormulaCell(Cell cell)方法,计算公式保存结果,但不改变公式。而evaluateInCell(Cell cell) 方法是计算公式,并将原公式替换为计算结果,也就是说该单元格的类型不在是Cell.CELL_TYPE_FORMULA Cell.CELL_TYPE_NUMBERIC

HSSFFormulaEvaluator提供了静态方法evaluateAllFormulaCells(HSSFWorkbook wb) ,计算一个Excel文件的所有公式,用起来很方便。

 

使用 poi 修改excel

下面是一个测试修改的类

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;

import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.ss.usermodel.WorkbookFactory;

public class UpdateExcel {
    
    public static void main(String args[]){
        InputStream inp;
        try {
            inp = new FileInputStream("hyperinks.xlsx");
            Workbook wb = WorkbookFactory.create(inp);
            Sheet sheet = wb.getSheetAt(0);
            Row row = sheet.getRow(2);
            Cell cella = row.getCell(0);
            cella.setCellValue("success!!");
            Cell cell = row.getCell(3);
            if (cell == null)
                cell = row.createCell(3);
            cell.setCellType(Cell.CELL_TYPE_STRING);
            cell.setCellValue("a test");

            // Write the output to a file
            FileOutputStream fileOut = new FileOutputStream("hyperinks.xlsx");
            wb.write(fileOut);
            fileOut.close();
        } catch (FileNotFoundException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (InvalidFormatException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        } catch (IOException e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        
    }
}

分享到:
评论

相关推荐

    POI操作Excel常用方法总结.docx

    本文主要总结了使用POI操作Excel的一些核心概念和常见方法。 首先,了解POI的基本概念: 1. **POI简介**:Apache POI是一个开源项目,其提供的API使得Java程序能够处理MS Office格式的文档,包括Excel(XLS和XLSX...

    POI操作Excel常用方法总结.pdf

    **Excel常用操作方法**: 1. **获取Excel对象**:首先,通过`POIFSFileSystem`打开文件系统,然后用`HSSFWorkbook`读取Excel工作簿,接着可以获取工作表、行和单元格。例如: ```java POIFSFileSystem fs = new ...

    POI操作Excel常用方法总结及对excel的读写举例讲述.docx

    EXCEL 常用操作方法** - **取得 sheet 的数目**:使用 `HSSFWorkbook` 的 `getNumberOfSheets()` 方法可以获取工作簿中的工作表数量。 - **取得一行的有效单元格个数**:通过调用 `HSSFRow` 的 `getLastCellNum()`...

    POI操作Excel常用方法总结及对excel的读写举例讲述.pdf

    四、EXCEL 常用操作方法 1. 获取 Excel 对象: - 使用 `POIFSFileSystem` 从文件中打开 Excel 文档。 - 通过 `HSSFWorkbook` 的构造函数创建工作簿对象。 - 使用 `getSheetAt(int index)` 获取指定索引的工作表。...

    java_poi操作excel

    **总结**:以上内容详细介绍了如何使用 Apache POI 在 Java 程序中创建和操作 Excel 文件。从创建 Excel 文件到设置单元格的内容,再到添加文档的摘要信息和批注,这些操作都是日常开发中非常实用且常见的功能。掌握...

    POI操作excel2003与2007

    ### POI操作Excel2003与2007 #### 一、POI简介与基础知识 POI是Apache组织下的一个开源项目组件之一,它提供了API来处理Microsoft Office格式的文件,包括Excel、Word、PowerPoint等。本文将重点介绍如何使用POI...

    poi 解析excel实例

    在描述中提到的“ poi解析excel的工具类”,通常包含了一些常用的方法,例如打开文件、读取单元格数据、处理合并单元格等。以下是一些可能包含在该工具类中的关键方法: 1. **打开文件**:使用`WorkbookFactory`类...

    java利用poi生成excel报表、处理word文档

    总结,Java POI库为开发者提供了一种高效、灵活的方式来处理Excel报表和Word文档,无论是在生成报表还是数据导入导出、文档格式转换等方面,都是一个不可或缺的工具。通过深入理解和实践,我们可以构建出满足各种...

    java_poi导入excel通用工具类V0915

    在Java领域,当你需要读取、写入或修改Excel文件时,POI库是一个非常常用的选择。"java_poi导入excel通用工具类V0915" 提供了一种通用的方式来处理Excel数据的导入工作,它支持多种赋值方式,包括单个对象、列表对象...

    POI实战总结

    四、 EXCEL常用操作方法 。 【1、得到Excel常用对象 2、建立Excel常用对象 3、设置sheet名称和单元格内容 4、取得sheet的数目 5、根据index取得sheet对象 6、取得有效的行数 7、取得一行的有效单元格个数 8...

    poi excel 2003 2007

    这两个文件名暗示了可能包含一个Java源代码文件(`ExcelUtil2.java`),该文件可能实现了使用Apache POI操作Excel的具体功能。`q.docx`可能是关于如何使用这些功能的文档或示例说明。为了更好地理解它们的内容,你...

    java操作excel的poi手册

    Java操作Excel的POI框架是Java开发者在处理Excel文件时常用的一个库,它允许程序员创建、修改和读取Microsoft Excel文件。本手册将详细介绍如何利用Apache POI进行Java与Excel的交互。 Apache POI是一个开源项目,...

    PoiExcel_single_save.rar

    总结,"PoiExcel_single_save.rar"项目演示了如何在Java环境中利用Apache POI进行Excel文件的读写操作,并结合ZBar二维码扫描技术实现数据的自动回填。这种组合在数据处理和自动化流程中有着广泛的应用前景,能够...

    java使用poi包和jxl包操作excel的心得

    Java作为一款流行的企业级开发语言,提供了多种工具来操作Excel文件,其中最为常用的当属Apache POI与JXL这两个开源库。 #### 二、Apache POI简介 Apache POI是一个用于读写Microsoft Office格式文件的Java API,...

    poi读取excel的应用

    在本文中,我们将深入探讨如何使用Apache POI库来读取Excel文件,这是Java开发人员处理Excel数据时常用的工具。 1. **Apache POI简介** Apache POI 提供了HSSF(Horrible Spreadsheet Format)和XSSF(XML ...

    java 操作Excel jxl poi 有例子

    "testExcel.rar"可能包含了使用Apache POI操作Excel的示例代码。 在POI中,我们可以使用`XSSFWorkbook`(对于.xlsx文件)或`HSSFWorkbook`(对于.xls文件)来读写Excel: ```java FileInputStream fis = new ...

    POI实战-java开发excel详解

    这种映射关系有助于程序员更直观地理解和操作Excel文件。 例如,考虑一个简单的Excel文件,它包含一个名为“Sheet1”的工作表,其中有4行4列的数据。在POI中,可以通过以下方式读取这些数据: - **表关系**:`...

Global site tag (gtag.js) - Google Analytics