poi导出excel2007报表时图片写入到excel2007后显示不出来如何解决?
在导出excel报表时,我是这样写入图片的:
xssfdrawing draw = sheet.createdrawingpatriarch();
draw.createpicture(anchor,workbook.addpicture(bytevalue,xssfworkbook.picture_type_png));
其中bytevalue是要显示图片的字节数组;
不知道是写入图片的方法没有用对还是其他什么原因,导出的excel没有将写入的图片显示出来,请各位高人指点。谢谢!
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
我今天也碰见了这个问题。 图片在Excel2003显示没有问题,但我用07把模板重新保存之后,写入的图片显示不出来了。 试了几次,只能归结于07改变了sheet的内部属性值。 但是我用07直接建一个*.xls的空文件,可以显示。我用的放座标方法用的是HSSFClientAnchor写入的。 我倒没有注意看我们POI版本,XSSFClientAnchor是针对07的吗?哪一版加的? 求指点。
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);
有人知道使用poi如何往excel中写入图片吗?写入后必须要能正常显示出来。