POI操作EXCEL插入图片


文章目录


POI操作EXCEL插入图片

依赖

xml 复制代码
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi</artifactId>
    <version>4.1.2</version>
</dependency>
<dependency>
    <groupId>org.apache.poi</groupId>
    <artifactId>poi-ooxml</artifactId>
    <version>4.1.2</version>
</dependency>

使用HSSFPatriarch来将图片写入EXCEL中

java 复制代码
BufferedImage bufferImg;//图片
ByteArrayOutputStream byteArrayOut = null;
try {
    // 先把读进来的图片放到一个ByteArrayOutputStream中,以便产生ByteArray
    byteArrayOut = new ByteArrayOutputStream();
    //将图片读到BufferedImage
    InputStream resource = Thread.currentThread().getContextClassLoader().getResourceAsStream(imageName);
    if(resource == null){
        throw new BusinessException("%s资源不存在",imageName);
    }
    bufferImg = ImageIO.read(resource);
    // 将图片写入流中
    ImageIO.write(bufferImg, "png", byteArrayOut);

    // 利用HSSFPatriarch将图片写入EXCEL
    HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
		// 定义单元格位置
    HSSFCreationHelper creationHelper = workbook.getCreationHelper();
    HSSFClientAnchor clientAnchor = creationHelper.createClientAnchor();
    clientAnchor.setCol1(columnNo);
    clientAnchor.setRow1(rowNo);


    // 插入图片  PICTURE_TYPE_PNG是图片的类型
    HSSFPicture picture = patriarch.createPicture(clientAnchor, workbook.addPicture(byteArrayOut
            .toByteArray(), HSSFWorkbook.PICTURE_TYPE_PNG));
    picture.resize(2.5);

} catch (IOException e) {
    LOGGER.error("图片写入excel失败", e);
} finally {
    if (byteArrayOut != null) {
        try {
            byteArrayOut.close();
        } catch (IOException e) {
            LOGGER.error("关闭流失败", e);
        }
    }

}

注:在将图片添加到工作簿中时,必须将其存储为字节数组


参考文献

相关推荐
Le1Yu15 小时前
消息队列以及RabbitMQ的使用
java·开发语言
羚羊角uou15 小时前
【Linux】线程池
java·开发语言
阿拉-M8315 小时前
IntelliJ IDEA Windows 系统高频快捷键使用手册
java·windows·intellij-idea
lingggggaaaa15 小时前
小迪安全v2023学习笔记(一百三十四讲)—— Windows权限提升篇&数据库篇&MySQL&MSSQL&Oracle&自动化项目
java·数据库·windows·笔记·学习·安全·网络安全
迦蓝叶16 小时前
JAiRouter v1.0.0 正式发布:企业级 AI 服务网关的开源解决方案
java·运维·人工智能·网关·spring·ai·开源
安卓开发者16 小时前
鸿蒙NEXT应用接入快捷栏:一键直达,提升用户体验
java·harmonyos·ux
yudiandian201416 小时前
03 Eclipse 配置 JDK 环境
java·ide·eclipse
_码力全开_16 小时前
P1005 [NOIP 2007 提高组] 矩阵取数游戏
java·c语言·c++·python·算法·矩阵·go
陈一Tender16 小时前
JavaWeb后端实战(登录认证 & 令牌技术 & 拦截器 & 过滤器)
java·开发语言·spring boot·mysql