ZBLOG

private void mergeFileSheet(File originalFile, List fileUrls) throws Exception { try (FileInputStream fis = new FileInputStream(originalFile); Workbook originalWorkbook = new XSSFWorkbook(fis)) { for (Strin...

要实现支持单元格图片复制,你可以对copyRow方法进行修改。以下是一种可能的优化方法:

  1. 首先,在copyRow方法中,获取源单元格的图片集合:
List<PictureData> pictures = workbook.getAllPictures();
  1. 在复制单元格样式之后,将源单元格中的图片应用到目标单元格:
for (PictureData picture : pictures) {
    if (picture == null) continue;

    // 获取源单元格中的图片索引
    int pictureIndex = workbook.addPicture(picture.getData(), picture.getPictureType());

    // 判断源单元格是否包含该图片
    if (sourceCell.getSheet().getDrawingPatriarch() != null && sourceCell.getSheet().getDrawingPatriarch().getChildren() != null) {
        for (XSSFShape shape : sourceCell.getSheet().getDrawingPatriarch().getShapes()) {
            if (!(shape instanceof XSSFPicture)) continue;

            XSSFPicture xssfPicture = (XSSFPicture) shape;
            XSSFClientAnchor anchor = xssfPicture.getClientAnchor();
            
            // 如果源单元格中的图片锚点与当前遍历到的图片锚点相同,则在目标单元格创建一个新的图片,并设置相同的锚点和索引
            if (anchor.getRow1() == sourceCell.getRowIndex() && anchor.getCol1() == sourceCell.getColumnIndex()) {
                XSSFDrawing drawing = targetSheet.createDrawingPatriarch();
                XSSFClientAnchor newAnchor = new XSSFClientAnchor(anchor.getDx1(), anchor.getDy1(), anchor.getDx2(),
                        anchor.getDy2(), targetCell.getColumnIndex(), targetCell.getRowIndex(),
                        targetCell.getColumnIndex(), targetCell.getRowIndex());
                XSSFPicture newPicture = drawing.createPicture(newAnchor, pictureIndex);
                break;
            }
        }
    }
}

通过以上优化,你可以实现将源单元格中的图片复制到目标单元格。请注意,上述代码适用于使用Apache POI库操作Excel文件的情况,且仅在XLSX格式下测试通过。如果使用其他库或其他文件格式,请相应地进行修改。


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=16322

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?