excel中判断指定的单元格是否是合并单元格 及 判断指定的行是否是合并行以及最大行值...

使用Apache 的poi 对excel中的数据行和danyuange进行判断

 /**

     * 判断指定的单元格是否是合并单元格
     * 
     * @param sheet
     * @param row  行下标
     * @param column 列下标
     * @return
     */
    public Map<String, String> isMergedRegion(Sheet sheet, int row, int column) {


        Map<String, String> map = new HashMap<String, String>();
        //判断结果
        String flag = "false";
        //当前行
        String r = "-1";
        //当前列
        String c = "-1";
        //最大row
        String mr = row + "";
        map.put("Row", r);
        map.put("Col", c);
        map.put("Result", flag);
        map.put("MaxRow", mr);
        // 得到一个sheet中有多少个合并单元格
        int sheetMergeCount = sheet.getNumMergedRegions();
        for (int i = 0; i < sheetMergeCount; i++) {
            // 获取合并后的单元格
            CellRangeAddress range = sheet.getMergedRegion(i);
            int firstColumn = range.getFirstColumn();
            int lastColumn = range.getLastColumn();
            int firstRow = range.getFirstRow();
            int lastRow = range.getLastRow();
            if (row >= firstRow && row <= lastRow) {
                if (column >= firstColumn && column <= lastColumn) {
                    flag = "true";
                    map.put("Row", firstRow + "");
                    map.put("Col", firstColumn + "");
                    map.put("Result", flag);
                    map.put("MaxRow", lastRow + "");
                    return map;
                }
            }
        }
        return map;
    }


    /**
     * 判断指定的行是否是合并行以及最大行值
     * 
     * @param sheet
     * @param row   行下标
     * @param column  列下标
     * @return
     */
    public Map<String, String> isMergedRow(Sheet sheet, int row, int column) {


        Map<String, String> map = new HashMap<String, String>();
        //判断结果
        String flag = "false";
        //最大row
        String mr = row + "";
        map.put("Results", flag);
        map.put("MaxRow", mr);
        // 得到一个sheet中有多少个合并单元格
        int sheetMergeCount = sheet.getNumMergedRegions();
        for (int i = 0; i < sheetMergeCount; i++) {
            // 获取合并后的单元格
            CellRangeAddress range = sheet.getMergedRegion(i);
            int firstColumn = range.getFirstColumn();
            int lastColumn = range.getLastColumn();
            int firstRow = range.getFirstRow();
            int lastRow = range.getLastRow();
            if (row >= firstRow && row <= lastRow) {
                if (column >= firstColumn && column <= lastColumn) {
                    flag = "true";
                    map.put("Results", flag);
                    map.put("MaxRow", lastRow + "");
                    return map;
                }
            }
        }
        return map;

    }

 

/*********************************************************/

所需依赖

        <dependency>
             <groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.9</version>
     </dependency>
     <dependency>
     <groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.9</version>
     </dependency>
<dependency>
     <groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml-schemas</artifactId>
<version>3.9</version>
     </dependency>

转载于:https://my.oschina.net/u/3820486/blog/1794131

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值