POI对word、excel进行单元格合并

实现代码

word

//获取需要操作的word文件
FileInputStream fileInputStream = new FileInputStream(path);
XWPFDocument document = new XWPFDocument(fileInputStream);
//获取表格 这里获取的是文件中最后一个表格
XWPFTable table = document.getTables().get(document.getTables().size() - 1);

调用方法

// word跨行并单元格
public static void mergeCellsVertically(XWPFTable table, int col, int fromRow, int toRow) {
       for (int rowIndex = fromRow; rowIndex <= toRow; rowIndex++) {
           XWPFTableCell cell = table.getRow(rowIndex).getCell(col);
           if ( rowIndex == fromRow ) {   cell.getCTTc().addNewTcPr().addNewVMerge().setVal(STMerge.RESTART);
            } else {
                cell.getCTTc().addNewTcPr().addNewVMerge().setVal(STMerge.CONTINUE);
            }
            cell.setVerticalAlignment(XWPFTableCell.XWPFVertAlign.CENTER);
        }
    }

最后保存

FileOutputStream fileOutputStream = new FileOutputStream(newPah);
document.write(fileOutputStream);
fileOutputStream.close();

excel

InputStream in = new FileInputStream(path);
XSSFWorkbook workbook = new XSSFWorkbook(in);
// 获取第一个工作表
XSSFSheet sheet = workbook.getSheetAt(0);
// 遍历行
Iterator<Row> rowIterator = sheet.iterator();
XSSFCellStyle cellStyle = workbook.createCellStyle();
XSSFFont font = workbook.createFont();
font.setFontHeightInPoints((short) 14);
font.setFontName("宋体");// 设置标题字体
cellStyle.setFont(font);
cellStyle = workbook.createCellStyle();
cellStyle.setAlignment(HSSFCellStyle.ALIGN_LEFT); // 居中
        Map<String,Integer> start = Maps.newHashMap();
        Map<String,Integer> end = Maps.newHashMap();
        while (rowIterator.hasNext()) {
            Row row = rowIterator.next();
            // 获取第一个单元格的值
            Cell cell = row.getCell(0);
            String cellValue = cell.getStringCellValue();
            //设置居中样式
            CellStyle style = workbook.createCellStyle();
            style.setVerticalAlignment(CellStyle.VERTICAL_CENTER);
            // 如果与上一行单元格的值相同,则合并单元格
            if (row.getRowNum() > 5) {
                if (start.containsKey(cellValue)){
                    end.put(cellValue,row.getRowNum());
                }else {
                    start.put(cellValue,row.getRowNum());
                }
            }
        }
        for (String key : start.keySet()) {
            if (end.containsKey(key)){
                CellRangeAddress cellRangeAddress = new CellRangeAddress(start.get(key), end.get(key), 0, 0);
                sheet.addMergedRegion(cellRangeAddress);
            }
        }
// 写出 Excel 文件
FileOutputStream outputStream = new FileOutputStream(newPath);
workbook.write(outputStream);
outputStream.close();
in.close();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

大能猫猫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值