Java -- POI -- 随笔汇总

1. 判断指定的单元格是否是合并单元格

    /**
     * 功能:判断指定的单元格是否是合并单元格
     * 原理:excel中的合并单元格其实就是首单元格,只不过该单元格增加了 rowspan和colspan两个属性。
     * 并且把该单元格的高度和宽度变成(例如rowspan=2,colspan=3)2行,3列的的标尺长度,再把被合并的单元格(除了首单元格的其余5个单元格)隐藏。
     * @param wsheet
     * @param row
     * @param column
     * @return
     */
    private Integer isMergedRegion(Sheet wsheet, int row, int column) {
        //getNumMergedRegions:得到所有区域
        for(int i = 0;i < wsheet.getNumMergedRegions();i++){
            //根据索引获取指定的合并单元区域
            CellRangeAddress range = wsheet.getMergedRegion(i);
            int firstColumn = range.getFirstColumn();
            int lasColumn = range.getLastColumn();
            int firstRow = range.getFirstRow();
            int lastRow = range.getLastRow();
            if(row >= firstRow && row <= lastRow){
                if(column >= firstColumn && column <= lasColumn){
                    return i;
                }
            }
        }
        return -1;
    }

2. 插入图片

public void addPictrue(String imgPath,HSSFSheet sheet, HSSFWorkbook wb){
                BufferedImage bufferImg = null;
                //先把读进来的图片放到一个ByteArrayOutputStream中,以便产生ByteArray    
                try {
                    ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();

                    bufferImg = ImageIO.read(new File(imgPath));
                    //这里要注意,第二个参数将会决定插入图片形式,如果是一个png的图片,背景透明,但是此处设置为jpg格式将会自动添加黑色背景
                    ImageIO.write(bufferImg, "png", byteArrayOut);
                    //画图的顶级管理器,一个sheet只能获取一个
                    HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
                    //anchor主要用于设置图片的属性  
                    //dx1、dy1、dx2、dy2、col1,row1,col2,row2
                    HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 255, 255,(short) 9, 0, (short) 11, 0);
                    anchor.setAnchorType(2);
                    //插入图片    
                    patriarch.createPicture(anchor, wb.addPicture(byteArrayOut.toByteArray(), HSSFWorkbook.PICTURE_TYPE_PNG));

                } catch (Exception e) {
                    e.printStackTrace();
                }finally{
                }
            }

3. 合并单元格

        //Test of Merging
        Row row = firstSheet.createRow(1);
        Cell cell = row.createCell(1);
        cell.setCellValue("test of merging");
        //firstRow、lastRow、firstCol、lastCol
        firstSheet.addMergedRegion(new CellRangeAddress(1,1,1,4));

4. 

        //设置生成Excel中公式自动计算
        wsheet.setForceFormulaRecalculation(true);

5. 

            //获取所有合并单元格的个数
            sheet.getNumMergedRegions();

6.

            //获取指定索引的合并区域
            region = sheet.getMergedRegion(i);

7.

                //拷贝合并区域
                CellRangeAddress newRegion = region.copy();

8.

                //设置合并区域的首行、首列、最后行、最后列
                newRegion.setFirstRow(targetRowFrom);
                newRegion.setFirstColumn(region.getFirstColumn());
                newRegion.setLastRow(targetRowTo);
                newRegion.setLastColumn(region.getLastColumn());

9.

                //向工作簿中添加合并区域
                sheet.addMergedRegion(newRegion);

10.

            //获取当前行的最后列索引
            columnCount = sourceRow.getLastCellNum();

11. 设置合并单元格样式

    /**
     * 功能:设置合并单元格样式
     * @param cellStyle
     * @param rangeAddress
     * @param wsheet
     */
    private void setRegionStyle(CellStyle cellStyle, CellRangeAddress rangeAddress, Sheet wsheet) {
        for(int i = rangeAddress.getFirstRow();i <= rangeAddress.getLastRow();i++){
            Row row = wsheet.getRow(i);
            if(null == row){
                row = wsheet.createRow(i);
            }
            for(int j = rangeAddress.getFirstColumn();j <= rangeAddress.getLastColumn();j++){
                Cell cell = row.getCell(j);
                if(null == cell){
                    cell = row.createCell(j);
                    cell.setCellValue("");
                }
                cell.setCellStyle(cellStyle);
            }
        }
    }

12. 转换坐标(B3)为行列值(row=4、col=1)

        //得到列 字母
        String lineStr = "";
        String reg = "[A-Z]+";
        Pattern p = Pattern.compile(reg);
        Matcher m = p.matcher(point);
        while (m.find()) {
            lineStr = m.group();
        }
        //将列字母转成列号 根据ASCII转换
        char[] ch = lineStr.toCharArray();
        int column = 0;
        for (int i = 0; i < ch.length; i++) {
            char c = ch[i];
            int post = ch.length - i - 1;
            int r = (int) Math.pow(10, post);
            column = column + r * ((int) c - 65);
        }
        tempCell.setColumn(column);

        //得到行号
        reg = "[1-9]\\d*";
        p = Pattern.compile(reg);
        m = p.matcher(point);
        while (m.find()) {
            tempCell.setRow((Integer.parseInt(m.group()) - 1));
        }

13.

啦啦啦

posted @ 2017-09-03 14:29  limeOracle  阅读(663)  评论(0编辑  收藏  举报