poi excel 插入图片

1 篇文章 0 订阅
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();
}
  • 1
    点赞
  • 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、付费专栏及课程。

余额充值