使用Npoi向Excel中插入圖片


  先把數據庫中的數據都導入到Excel表格中,把圖片地址的路徑全部轉成絕對路徑。
  使用Npoi讀取剛導出的Excle表格,把圖片那個單元格的圖片路徑讀出來,然后用文件流讀取圖片,然后通過Npoi把圖片放到當前單元格中。

 1  1 //add picture data to this workbook.
 2  2 byte[] bytes = System.IO.File.ReadAllBytes(@"D:\MyProject\NPOIDemo\ShapeImage\image1.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();


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM