POI 向Excel插入图片

                        // 插入 PNG 图片至 Excel     		  
  	  		InputStream is = new FileInputStream("图片路径");  
  	  		byte[] bytes = IOUtils.toByteArray(is);    		  
  	  		int pictureIdx = wb.addPicture(bytes, Workbook.PICTURE_TYPE_PNG);    		  
  	  		CreationHelper helper = wb.getCreationHelper();  
  	  		Drawing drawing = sheet.createDrawingPatriarch();  
  	  		ClientAnchor anchor = helper.createClientAnchor();   		  
  	  		// 图片插入坐标  
  	  		anchor.setCol1(6);  //列
  	  		anchor.setRow1(0);  //行
  	  		// 插入图片  
  	  		Picture pict = drawing.createPicture(anchor, pictureIdx);  
  	  		pict.resize(); 


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用Apache POI的XSSFDrawing类来向Excel插入图片。下面是一个简单的示例代码: ``` import java.io.*; import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.*; import org.apache.poi.util.IOUtils; public class InsertImageToExcel { public static void main(String[] args) throws Exception { // 创建Excel文档对象 XSSFWorkbook workbook = new XSSFWorkbook(); // 创建工作表对象 XSSFSheet sheet = workbook.createSheet("Sheet1"); // 读取图片文件 InputStream imageStream = new FileInputStream("image.jpg"); byte[] bytes = IOUtils.toByteArray(imageStream); // 向Excel插入图片 int pictureIdx = workbook.addPicture(bytes, Workbook.PICTURE_TYPE_JPEG); Drawing drawing = sheet.createDrawingPatriarch(); ClientAnchor anchor = drawing.createAnchor(0, 0, 0, 0, 0, 0, 5, 5); Picture picture = drawing.createPicture(anchor, pictureIdx); picture.resize(); // 保存Excel文件 FileOutputStream fileOut = new FileOutputStream("workbook.xlsx"); workbook.write(fileOut); fileOut.close(); System.out.println("图片已成功插入Excel文件!"); } } ``` 在上面的代码中,我们首先读取图片文件并将其转换为字节数组,然后使用`Workbook.addPicture()`方法将图片添加到Excel工作簿中。接下来,我们创建一个绘图对象,并使用`Drawing.createAnchor()`创建一个插图锚点,然后使用`Drawing.createPicture()`将图片插入到锚点位置。最后,我们调用`Picture.resize()`方法来调整图片大小以适应单元格。 请注意,上面的示例代码只适用于XLSX格式的Excel文件。如果要处理XLS格式的文件,需要使用HSSFWorkbook和HSSFPicture类。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值