Java向Excel中插入图片

  1. import java.io.FileOutputStream;   
  2. import java.io.File;   
  3. import java.io.ByteArrayOutputStream;   
  4. import java.io.IOException;   
  5.   
  6. import java.awt.image.BufferedImage;   
  7. import javax.imageio.*;   
  8.   
  9. import org.apache.poi.hssf.usermodel.HSSFWorkbook;   
  10. import org.apache.poi.hssf.usermodel.HSSFSheet;   
  11. import org.apache.poi.hssf.usermodel.HSSFPatriarch;   
  12. import org.apache.poi.hssf.usermodel.HSSFClientAnchor;;   
  13.   
  14. public class TestPOI {   
  15.   
  16.     public static void main(String[] args) {   
  17.             FileOutputStream fileOut = null;   
  18.             BufferedImage bufferImg =null;   
  19.             BufferedImage bufferImg1 = null;   
  20.             try{   
  21.                  
  22.           //先把读进来的图片放到一个ByteArrayOutputStream中,以便产生ByteArray   
  23.           ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();   
  24.           ByteArrayOutputStream byteArrayOut1 = new ByteArrayOutputStream();   
  25.           bufferImg = ImageIO.read(new File("d:/PieChart.jpg"));   
  26.           bufferImg1 = ImageIO.read(new File("d:/fruitBarChart.jpg"));   
  27.           ImageIO.write(bufferImg,"jpg",byteArrayOut);   
  28.           ImageIO.write(bufferImg1,"jpg",byteArrayOut1);   
  29.            
  30.         //创建一个工作薄   
  31.        HSSFWorkbook wb = new HSSFWorkbook();   
  32.        HSSFSheet sheet1 = wb.createSheet("new sheet");   
  33.        //HSSFRow row = sheet1.createRow(2);   
  34.        HSSFPatriarch patriarch = sheet1.createDrawingPatriarch();   
  35.        HSSFClientAnchor anchor = new HSSFClientAnchor(0,0,512,255,(short1,1,(short)10,20);   
  36.        HSSFClientAnchor anchor1 = new HSSFClientAnchor(0,0,512,255,(short2,30,(short)10,60);   
  37.        anchor1.setAnchorType(2);   
  38.        //插入图片   
  39.        patriarch.createPicture(anchor , wb.addPicture(byteArrayOut.toByteArray(),HSSFWorkbook.PICTURE_TYPE_JPEG));   
  40.        patriarch.createPicture(anchor1 , wb.addPicture(byteArrayOut1.toByteArray(),HSSFWorkbook.PICTURE_TYPE_JPEG));   
  41.          
  42.            fileOut = new FileOutputStream("d:/workbook.xls");   
  43.            //写入excel文件   
  44.            wb.write(fileOut);   
  45.            fileOut.close();   
  46.          
  47.             }catch(IOException io){   
  48.                     io.printStackTrace();   
  49.                     System.out.println("io erorr : "+ io.getMessage());   
  50.             } finally  
  51.             {   
  52.                if (fileOut != null)   
  53.                {   
  54.                             
  55.                    try {   
  56.                               fileOut.close();   
  57.                          }   
  58.                    catch (IOException e)   
  59.                    {   
  60.                             // TODO Auto-generated catch block   
  61.                             e.printStackTrace();   
  62.                      }   
  63.                }   
  64.             }   
  65.     }   
  66. }  
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值