zoukankan      html  css  js  c++  java
  • 使用Npoi向Excel中插入图片

      先把数据库中的数据都导入到Excel表格中,把图片地址的路径全部转成绝对路径。
      使用Npoi读取刚导出的Excle表格,把图片那个单元格的图片路径读出来,然后用文件流读取图片,然后通过Npoi把图片放到当前单元格中。

     1  1 //add picture data to this workbook.
     2  2 byte[] bytes = System.IO.File.ReadAllBytes(@"D:MyProjectNPOIDemoShapeImageimage1.jpg");
     3  3 int pictureIdx = hssfworkbook.AddPicture(bytes, HSSFWorkbook.PICTURE_TYPE_JPEG);
     4  4 
     5  5 //create sheet
     6  6 HSSFSheet sheet = hssfworkbook.CreateSheet("Sheet1");
     7  7 
     8  8 // Create the drawing patriarch.  This is the top level container for all shapes. 
     9  9 HSSFPatriarch patriarch = sheet.CreateDrawingPatriarch();
    10 10 
    11 11 //add a picture
    12 12 HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 1023, 0, 0, 0, 1, 3);
    13 13  HSSFPicture pict = patriarch.CreatePicture(anchor, pictureIdx);
    View Code

         与画简单图形不同的是,首先要将图片读入到byte数组,然后添加到workbook中;最后调用的是patriarch.CreatePicture(anchor, pictureIdx)方法显示图片,而不是patriarch.CreateSimpleShape(anchor)方法。上面这段代码执行后生成的Excel文件样式如下: 
          我们发现,插入的图片被拉伸填充在HSSFClientAnchor指定的区域。有时可能我们并不需要拉伸的效果,很简单,在最后加上这样一句用来自动调节图片大小:

    pict.Resize();
  • 相关阅读:
    LOJ-10096(强连通+bfs)
    LOJ-10095(缩点的特殊使用)
    LOJ-10094(强连通分量)
    LOJ-10092(最大半连通子图)
    【BZOJ3489】A simple rmq problem(KD-Tree)
    UVA10384 推门游戏 The Wall Pushers(IDA*)
    [SCOI2005]骑士精神(IDA*)
    浅谈A*算法
    【模板】K-D Tree
    【XSY1953】【BZOJ4012】【HNOI2015】开店(动态点分治)
  • 原文地址:https://www.cnblogs.com/qigang/p/3489684.html
Copyright © 2011-2022 走看看