开发者社区> 问答> 正文

easypoi合并列怎么写:报错

@Anotherjueyue 你好,想跟你请教个问题:
easypoi合并列怎么写,我用的标签方式

我想实现手别是合并的

---

展开
收起
kun坤 2020-06-09 09:30:37 2351 0
2 条回答
写回答
取消 提交回答
  • github.com/xuri

    推荐一个功能丰富、兼容性好、高性能的 Excel 文档基础库 Excelize:https://github.com/xuri/excelize https://xuri.me/excelize/images/excelize.svg

    2020-12-14 10:33:37
    赞同 1 展开评论 打赏
  • package org.jeecgframework.poi.util;
    
    import java.util.ArrayList;
    import java.util.HashMap;
    import java.util.List;
    import java.util.Map;
    import java.util.Set;
    
    import org.apache.commons.lang3.StringUtils;
    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.util.CellRangeAddress;
    import org.jeecgframework.poi.excel.entity.params.MergeEntity;
    
    /**
     * 纵向合并单元格工具类
     * @author JueYue
     * @date 2015年6月21日 上午11:21:40
     */
    public final class PoiMergeCellUtil {
    
        private PoiMergeCellUtil() {
        }
    
        /**
         * 纵向合并相同内容的单元格
         * 
         * @param sheet
         * @param mergeMap key--列,value--依赖的列,没有传空
         * @param startRow 开始行
         */
        public static void mergeCells(Sheet sheet, Map<Integer, int[]> mergeMap, int startRow) {
            Map<Integer, MergeEntity> mergeDataMap = new HashMap<Integer, MergeEntity>();
            if (mergeMap.size() == 0) {
                return;
            }
            Row row;
            Set<Integer> sets = mergeMap.keySet();
            String text;
            for (int i = startRow; i <= sheet.getLastRowNum(); i++) {
                row = sheet.getRow(i);
                for (Integer index : sets) {
                    if (row.getCell(index) == null) {
                        mergeDataMap.get(index).setEndRow(i);
                    } else {
                        text = row.getCell(index).getStringCellValue();
                        if (StringUtils.isNotEmpty(text)) {
                            hanlderMergeCells(index, i, text, mergeDataMap, sheet, row.getCell(index),
                                mergeMap.get(index));
                        } else {
                            mergeCellOrContinue(index, mergeDataMap, sheet);
                        }
                    }
                }
            }
            if (mergeDataMap.size() > 0) {
                for (Integer index : mergeDataMap.keySet()) {
                    sheet.addMergedRegion(new CellRangeAddress(mergeDataMap.get(index).getStartRow(),
                        mergeDataMap.get(index).getEndRow(), index, index));
                }
            }
    
        }
    
        /**
         * 处理合并单元格
         * 
         * @param index
         * @param rowNum
         * @param text
         * @param mergeDataMap
         * @param sheet
         * @param cell
         * @param delys
         */
        private static void hanlderMergeCells(Integer index, int rowNum, String text,
                                              Map<Integer, MergeEntity> mergeDataMap, Sheet sheet,
                                              Cell cell, int[] delys) {
            if (mergeDataMap.containsKey(index)) {
                if (checkIsEqualByCellContents(mergeDataMap.get(index), text, cell, delys, rowNum)) {
                    mergeDataMap.get(index).setEndRow(rowNum);
                } else {
                    sheet.addMergedRegion(new CellRangeAddress(mergeDataMap.get(index).getStartRow(),
                        mergeDataMap.get(index).getEndRow(), index, index));
                    mergeDataMap.put(index, createMergeEntity(text, rowNum, cell, delys));
                }
            } else {
                mergeDataMap.put(index, createMergeEntity(text, rowNum, cell, delys));
            }
        }
    
        /**
         * 字符为空的情况下判断
         * 
         * @param index
         * @param mergeDataMap
         * @param sheet
         */
        private static void mergeCellOrContinue(Integer index, Map<Integer, MergeEntity> mergeDataMap,
                                                Sheet sheet) {
            if (mergeDataMap.containsKey(index)
                && mergeDataMap.get(index).getEndRow() != mergeDataMap.get(index).getStartRow()) {
                sheet.addMergedRegion(new CellRangeAddress(mergeDataMap.get(index).getStartRow(),
                    mergeDataMap.get(index).getEndRow(), index, index));
                mergeDataMap.remove(index);
            }
        }
    
        private static MergeEntity createMergeEntity(String text, int rowNum, Cell cell, int[] delys) {
            MergeEntity mergeEntity = new MergeEntity(text, rowNum, rowNum);
            List<String> list = new ArrayList<String>(delys.length);
            mergeEntity.setRelyList(list);
            for (int i = 0; i < delys.length; i++) {
                list.add(getCellNotNullText(cell, delys[i], rowNum));
            }
            return mergeEntity;
        }
    
        private static boolean checkIsEqualByCellContents(MergeEntity mergeEntity, String text,
                                                          Cell cell, int[] delys, int rowNum) {
            // 没有依赖关系
            if (delys == null || delys.length == 0) {
                return mergeEntity.getText().equals(text);
            }
            // 存在依赖关系
            if (mergeEntity.getText().equals(text)) {
                for (int i = 0; i < delys.length; i++) {
                    if (!getCellNotNullText(cell, delys[i], rowNum).equals(
                        mergeEntity.getRelyList().get(i))) {
                        return false;
                    }
                }
                return true;
            }
            return false;
        }
    
        /**
         * 获取一个单元格的值,确保这个单元格必须有值,不然向上查询
         * 
         * @param cell
         * @param index
         * @param rowNum
         * @return
         */
        private static String getCellNotNullText(Cell cell, int index, int rowNum) {
            String temp = cell.getRow().getCell(index).getStringCellValue();
            while (StringUtils.isEmpty(temp)) {
                temp = cell.getRow().getSheet().getRow(--rowNum).getCell(index).getStringCellValue();
            }
            return temp;
        }
    
    }
    之前版本模板没有合并单元格的属性,现在把那段功能提出出来了,你可以直接使用下 

    ######你好,请问下你用jxls怎么动态合并的单元格######不用这个了 我用了jxls实现了 感觉那个好用些######合并what?一列同样的数据吗?######类似这种效果 http://blog.csdn.net/hu_shengyang/article/details/6736816######全部显示 “一手”######你看第一张图的 “手别” 应该要合并的

    2020-06-09 09:30:53
    赞同 展开评论 打赏
问答地址:
问答排行榜
最热
最新

相关电子书

更多
低代码开发师(初级)实战教程 立即下载
冬季实战营第三期:MySQL数据库进阶实战 立即下载
阿里巴巴DevOps 最佳实践手册 立即下载