日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Winforn中通过NPOI导出Excel时通过XSSFClientAnchor和XSSFPicture添加图片

發布時間:2025/3/19 编程问答 43 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Winforn中通过NPOI导出Excel时通过XSSFClientAnchor和XSSFPicture添加图片 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

場景

Winform中通過NPOI導出Excel的三種方式(HSSFWorkbook,XSSFWorkbook,SXSSFWorkbook)附代碼下載:

https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/106423452

在上面介紹了NPOI的三種導出Excel的方式后,如果想在導出的Excel中添加照片,該怎樣實現。

注:

博客主頁:
https://blog.csdn.net/badao_liumang_qizhi
關注公眾號
霸道的程序猿
獲取編程相關電子書、教程推送與免費下載。

實現

通過上面的博客添加了NPOI的引用后,拖拽一個按鈕,在按鈕的點擊事件中

private void button1_Click(object sender, EventArgs e){//新建XSSFWorkbook對象XSSFWorkbook wb = new XSSFWorkbook();#region 設置樣式ICellStyle style1 = wb.CreateCellStyle();//樣式IFont font1 = wb.CreateFont();//字體font1.FontName = "宋體";font1.FontHeightInPoints = 11;font1.Boldweight = (short)FontBoldWeight.Bold;style1.SetFont(font1);//樣式里的字體設置具體的字體樣式#endregion#region 基礎信息頁sheetISheet sheet0 = wb.CreateSheet("圖形");//獲取圖像System.Drawing.Image image = Properties.Resources.badao;Byte[] bytes = ImageToBytes(image);int widthPx = image.Width;int heightPx = image.Height;int pictureIdx = wb.AddPicture(bytes, PictureType.JPEG);XSSFDrawing patriarch = (XSSFDrawing)sheet0.CreateDrawingPatriarch();// 插圖片的位置? HSSFClientAnchor(dx1,dy1,dx2,dy2,col1,row1,col2,row2)XSSFClientAnchor anchor = new XSSFClientAnchor(0, 0, 0, 0, 0, 3, 1, 4);//把圖片插到相應的位置XSSFPicture pict = (XSSFPicture)patriarch.CreatePicture(anchor, pictureIdx);//設置列寬度,根據公式:POI中的列寬 ≈ 像素/8*256decimal width = Math.Round((decimal)(heightPx) / 8, 2);//將圖片縮小為原來的十分之九decimal lessWidth = Math.Round(width * 9 / 10, 2);sheet0.SetColumnWidth(0, Decimal.ToInt32(lessWidth * 256));IRow row3 = sheet0.CreateRow(3);//設置行高度,根據公式:POI中的行高 = 像素/DPI*72*20decimal poiHeight = Math.Round((decimal)(widthPx) / dpi, 2);//將圖片縮小為原來的十分之九decimal lessPoiHeight = Math.Round(poiHeight * 9 / 10, 2);row3.Height = (short)Decimal.ToInt32(lessPoiHeight * 72 * 20);#endregiontry{//將內存中的數據寫入磁盤using (FileStream filestream = new FileStream(System.IO.Path.Combine(@"D:\", "badao.xlsx"), FileMode.Create)){wb.Write(filestream);filestream.Close();}}catch (Exception ex){Console.Write(ex);}}

其中用到了將image轉為byte數組的方法

??????? public byte[] ImageToBytes(Image image){ImageFormat format = image.RawFormat;using (MemoryStream ms = new MemoryStream()){image.Save(ms, ImageFormat.Bmp);byte[] buffer = new byte[ms.Length];//Image.Save()會改變MemoryStream的Position,需要重新Seek到Beginms.Seek(0, SeekOrigin.Begin);ms.Read(buffer, 0, buffer.Length);return buffer;}}

用到的圖片的資源文件在Resouce中添加的

?

運行項目,然后點擊按鈕,就會在D盤下生成Excel

?

總結

以上是生活随笔為你收集整理的Winforn中通过NPOI导出Excel时通过XSSFClientAnchor和XSSFPicture添加图片的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。