poi excel 插入图片

本文介绍如何使用Java操作Excel文件,具体实现包括从指定路径读取Excel文件,将两张图片转换为字节数组并插入到Excel指定位置,最终保存文件。文章通过示例代码详细展示了如何利用HSSFWorkbook进行图片插入的具体步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public static void main(String arg[]) throws IOException{
printExcel();
}


/**

* 3.7去除所有图片再插入,3.10直接插入图片,原来图片还在
* @throws IOException
*/
public static void printExcel() throws IOException{
InputStream is = new FileInputStream("C:/Users/25709/Desktop/jqbmb.xls");
HSSFWorkbook wb= new HSSFWorkbook(is);
HSSFRow row=null;
HSSFCell cell=null;
HSSFSheet sheet=wb.getSheetAt(0);
String imgPath = "D:/二维码生成/Relieved_QRCode.png";  


BufferedImage bufferImg = null;   
BufferedImage bufferImg1 = null;
//先把读进来的图片放到一个ByteArrayOutputStream中,以便产生ByteArray     
ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();     
bufferImg = ImageIO.read(new File(imgPath));     
ImageIO.write(bufferImg, "png", byteArrayOut);  


ByteArrayOutputStream byteArrayOut1 = new ByteArrayOutputStream();
bufferImg1 = ImageIO.read(new File("C:/Users/25709/Desktop/log.png"));
ImageIO.write(bufferImg1, "png", byteArrayOut1);
//画图的顶级管理器,一个sheet只能获取一个(一定要注意这点)  
HSSFPatriarch patriarch = sheet.createDrawingPatriarch();     
//anchor主要用于设置图片的属性 , (short) 6, 12, (short)6, 15是图片所占单元格(对点正方形区域),(50=x1, 80=y1, 800=x2, 200=y2)
//对点正方形区域内(x1,y1),(x2,y2)是图片的坐标
HSSFClientAnchor anchor = new HSSFClientAnchor(50, 80, 800, 200,(short) 6, 12, (short)6, 15);    
anchor.setAnchorType(3);
HSSFClientAnchor anchor1 = new HSSFClientAnchor(300, 150, 600, 200,(short) 0, 0, (short) 1, 2);
anchor1.setAnchorType(3);
//插入图片    
patriarch.createPicture(anchor, wb.addPicture(byteArrayOut.toByteArray(), HSSFWorkbook.PICTURE_TYPE_PNG));
patriarch.createPicture(anchor1, wb.addPicture(byteArrayOut1.toByteArray(), HSSFWorkbook.PICTURE_TYPE_PNG));

FileOutputStream os;
os = new FileOutputStream("C:/Users/25709/Desktop/jqbmb.xls");
wb.write(os);
os.close();
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值