poi导出excel2007报表时图片写入到excel2007后显示不出来如何解决?

发布于 2021-11-23 14:18:03 字数 292 浏览 881 评论 3

在导出excel报表时,我是这样写入图片的:

xssfdrawing draw = sheet.createdrawingpatriarch();

draw.createpicture(anchor,workbook.addpicture(bytevalue,xssfworkbook.picture_type_png));

其中bytevalue是要显示图片的字节数组;

不知道是写入图片的方法没有用对还是其他什么原因,导出的excel没有将写入的图片显示出来,请各位高人指点。谢谢!

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

泪冰清 2021-11-24 05:04:21

我今天也碰见了这个问题。 图片在Excel2003显示没有问题,但我用07把模板重新保存之后,写入的图片显示不出来了。 试了几次,只能归结于07改变了sheet的内部属性值。 但是我用07直接建一个*.xls的空文件,可以显示。我用的放座标方法用的是HSSFClientAnchor写入的。 我倒没有注意看我们POI版本,XSSFClientAnchor是针对07的吗?哪一版加的? 求指点。

屌丝范 2021-11-23 20:39:39

Drawing patriarch = sheet.createDrawingPatriarch();

ClientAnchor anchor = null;

if(workBook instanceof HSSFWorkbook){

anchor = new HSSFClientAnchor(dx1, dy1, dx2, dy2,

col1, row1, col2, row2);

}else{

anchor = new XSSFClientAnchor(dx1, dy1, dx2, dy2,

col1, row1, col2, row2);

}

// 插入图片

byte[] pictureData = byteArrayOutputStream.toByteArray();

int pictureFormat = HSSFWorkbook.PICTURE_TYPE_JPEG;

int pictureIndex = workBook.addPicture(pictureData, pictureFormat);

patriarch.createPicture(anchor, pictureIndex);

带上头具痛哭 2021-11-23 15:24:18

有人知道使用poi如何往excel中写入图片吗?写入后必须要能正常显示出来。

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文