1. 设置单元格样式 

    HSSFCellStyle类代表一种单元格样式。可以通过这个类来设置单元格的边框样式背景颜色字体水平垂直对齐方式等等。

     

    HSSFCellStyle titleStyle = workbook.createCellStyle();
      titleStyle.setBorderBottom(HSSFCellStyle.BORDER_DOUBLE);
      titleStyle.setBorderLeft((short)1);
      titleStyle.setBorderRight((short)1);
      titleStyle.setBorderTop(HSSFCellStyle.BORDER_DOUBLE);
      titleStyle.setFillForegroundColor(HSSFColor.LIGHT_ORANGE.index);
      titleStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);

     

    注意:如果我们定义了一种样式,把它赋给一些单元格。然后基于新的需要,更改该样式中的某个属性,再赋给另一些单元格。那么之前单元格样式的该属性也会被同时更改。

    比如我们定义了样式,设置单元格背景色为红色:

     

    HSSFCellStyle cellStyle = workbook.createCellStyle();

    cellStyle.setFillForegroundColor(HSSFColor.RED.index);
    cellStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);

     

    然后把它赋给一个单元格:

     

    HSSFCell cell1 = row.createCell((short)1);

    cell1.setCellStyle(cellStyle);

     

    然后更改样式中的背景色属性为蓝色:

     

    cellStyle.setFillForegroundColor(HSSFColor.BLUE.index);

     

    然后赋给另一个单元格:

     

    HSSFCell cell2 = row.createCell((short)2);

    cell2.setCellStyle(cellStyle);

     

    想当然,我们预计在最终结果中cell1的背景色为红色,cell2的背景色为蓝色。但是结果是:两个单元格的背景色都变成了蓝色。

     

    遇到这种情况,要预先定义两种不同的单元格样式。

     

    当一个EXCEL文件同时需要很多大同小异的单元格样式时,这样一一定义很麻烦。POI HSSF提供了一个HSSFCellUtil类(在org.apache.poi.hssf.usermodel.contrib包),里面有几个方法可以绕过HSSFCellStyle直接设定单元格的样式,但这几个方法会抛出NestableException异常,要处理这个异常,需要引用Apache的几个Common包:

    commons-beanutils.jar

    commons-beanutils-bean-collections.jar

    commons-beanutils-core.jar

    commons-lang.jar

    commons-logging-api.jar

     

    合并单元格

    HSSFSheet.addMergedRegion(new Region())方法可以合并单元格,Region()中的一个构造函数含有四个参数,分别代表起始行、起始列、结束行、结束列:

    sheet.addMergedRegion(new Region(startRow,startCell,endRow,endCell)));

     

    处理公式

     

    HSSFCell.setCellFormula()方法用来在EXCEL单元格中写入公式。

       cell = row.createCell((short)(dataFlag));
       cell.setCellType(HSSFCell.CELL_TYPE_FORMULA);
       cell.setCellFormula("SUM("A1:D1")");
       cell.setCellStyle(nameStyle);

     

    处理链接

     

    在POI中往单元格中写链接,是用HYPERLINK函数搞定的。

    HYPERLINK函数包含两个参数,第一个参数是指向的URL地址,第二个参数是显示字串。

     

       cell = row.createCell((short)(dataFlag));
       cell.setCellType(HSSFCell.CELL_TYPE_FORMULA);
       cell.setCellFormula("HYPERLINK('链接地址http...')");
       cell.setCellStyle(linkStyle);

     

    为了使链接效果更好,我们可以给链接所在单元格定义一种样式,使链接显示为有下划线的蓝色字串:

     

      HSSFCellStyle linkStyle = workbook.createCellStyle();
      linkStyle.setBorderBottom((short)1);
      linkStyle.setBorderLeft((short)1);
      linkStyle.setBorderRight((short)1);
      linkStyle.setBorderTop((short)1);
      linkStyle.setFillForegroundColor(HSSFColor.SKY_BLUE.index);
      linkStyle.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
      HSSFFont font = workbook.createFont();
      font.setFontName(HSSFFont.FONT_ARIAL);
      font.setUnderline((byte)1);
      font.setColor(HSSFColor.BLUE.index);
      linkStyle.setFont(font);

     

    中文处理:

     

    要在通过POI生成的EXCEL中正常显示中文,需要为单元格设置编码:

     

    cell.setEncoding(HSSFCell.ENCODING_UTF_16);
      cell.setCellValue("部门");

Java使用HSSF读取Excel表中公式列的方法
    FileInputStream fis = new FileInputStream("c:/temp/test.xls");
    HSSFWorkbook wb = new HSSFWorkbook(fis);
    HSSFSheet sheet = wb.getSheetAt(0);
    HSSFFormulaEvaluator evaluator = new HSSFFormulaEvaluator(sheet, wb);

    // suppose your formula is in B3
    CellReference cellReference = new CellReference("B3");
    HSSFRow row = sheet.getRow(cellReference.getRow());
    HSSFCell cell = row.getCell(cellReference.getCol());
    //设置单元格所在行
    evaluator.setCurrentRow(row);
    HSSFFormulaEvaluator.CellValue cellValue = evaluator.evaluate(cell);

    switch (cellValue.getCellType()) {
    case HSSFCell.CELL_TYPE_BOOLEAN:
        System.out.println(cellValue.getBooleanValue());
        break;
    case HSSFCell.CELL_TYPE_NUMERIC:
        System.out.println(cellValue.getNumberValue());
        break;
    case HSSFCell.CELL_TYPE_STRING:
        System.out.println(cellValue.getStringValue());
        break;
    case HSSFCell.CELL_TYPE_BLANK:
        break;
    case HSSFCell.CELL_TYPE_ERROR:
        break;

    // CELL_TYPE_FORMULA will never happen
    case HSSFCell.CELL_TYPE_FORMULA:
        break;
    }