使用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();

转载于:https://www.cnblogs.com/qigang/p/3489684.html

在C#使用NPOI库操作Excel插入图片需要几个步骤。NPOI是一个开源的.NET库,用于读写Microsoft Office格式的文件,包括Excel。以下是插入图片的基本过程: 1. 引入所需命名空间: ```csharp using NPOI.HSSF.UserModel; using NPOI.ss.usermodel; using NPOI.XSSF.usermodel; using System.IO; ``` 2. 创建一个新的HSSFWorkbook或XSSFWorkbook对象(取决于你是处理旧版的xls还是xlsx文件)。 3. 创建一个新的Sheet对象。 4. 获取一个Graphics对象,通常在单元格内绘制图片之前会创建这个对象: ```csharp byte[] imageBytes = File.ReadAllBytes("path_to_your_image.jpg"); // 替换为实际图片路径 short colIndex = 0; // 列索引 short rowIndex = 0; // 行索引 // 对于HSSF(xls) HSSFPatriarch patriarch = ws.CreateDrawingPatriarch(); HSSFClientAnchor anchor = new HSSFClientAnchor(0, 0, 0, 0, colIndex + 1, rowIndex, colIndex + 1, rowIndex + 1); Image img = ImageFactory.CreateFromStream(new MemoryStream(imageBytes)); patriarch.AddChild(img); img.SetAnchor(anchor); // 或者对于XSSF(xlsx) XSSFShape shape = ws.Drawings.CreatePictureShape(colIndex, rowIndex, imageBytes.Length); shape.Width DrawingUtils.PixelsToPoints(15); // 设置宽度,单位为点 shape.Height DrawingUtils.PixelsToPoints(15); // 设置高度,单位为点 shape.SetPictureData(new byte[imageBytes.Length], imageBytes); ``` 5. 将图像保存到指定位置: ```csharp ws.WriteRow(rowIndex, colIndex, null); // 写入空行以便放置图片 ``` 6. 最后记得保存整个工作簿: ```csharp if (isXls) { usingFileStream = new FileStream(filePath, FileMode.Create); wb.Save(isXlsFileStream); } else if (isXlsx) { usingFileStream = new FileStream(filePath, FileMode.Create); ((XSSFWorkbook)wb).Save((FileStream)usingFileStream); } usingFileStream.Close(); ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值