c#在Excel指定单元格中插入图片

方法一:

/// 将图片插入到指定的单元格位置,并设置图片的宽度和高度。
/// 注意:图片必须是绝对物理路径
/// </summary>
/// <param name="RangeName">单元格名称,例如:B4</param>
/// <param name="PicturePath">要插入图片的绝对路径。</param>
public void InsertPicture(string RangeName, Excel._Worksheet sheet, string PicturePath)
{
 Excel.Range rng = (Excel.Range)sheet.get_Range(RangeName, Type.Missing);
rng.Select();
float PicLeft, PicTop, PicWidth, PicHeight;    //距离左边距离,顶部距离,图片宽度、高度
PicTop = Convert.ToSingle(rng.Top) ;
PicWidth = Convert.ToSingle(rng.MergeArea.Width);
PicHeight = Convert.ToSingle(rng.Height);
PicWidth = Convert.ToSingle(rng.Width);
PicLeft = Convert.ToSingle(rng.Left);//+ (Convert.ToSingle(rng.MergeArea.Width) - PicWidth) / 2;
try
{
Excel.Pictures pics = (Excel.Pictures)sheet.Pictures(Type.Missing);
pics.Insert(PicturePath, Type.Missing);
pics.Left = (double)rng.Left;
pics.Top = (double)rng.Top;
pics.Width = (double)rng.Width;
pics.Height = (double)rng.Height;

}
catch
{
}
//sheet.Shapes.AddPicture(PicturePath, Microsoft.Office.Core.MsoTriState.msoFalse,
// Microsoft.Office.Core.MsoTriState.msoTrue, PicLeft, PicTop, PicWidth, PicHeight);
}

如果是要在某个区域插入,改区域没有命名的话,直接传入选中区域

Cell1 = SourceSheet.Cells[第几行, 第几列];
Cell2 = SourceSheet.Cells[Row , Column];

SourceRange = SourceSheet.get_Range(Cell1, Cell2);

然后把上面的这句去掉 Excel.Range rng = (Excel.Range)sheet.get_Range(RangeName, Type.Missing);

把rng换成SourceRange

方法二:

sheet.Shapes.AddPicture(。。。。。)

/// 将图片插入到指定的单元格位置,并设置图片的宽度和高度。
/// 注意:图片必须是绝对物理路径
/// </summary>
/// <param name="rng">Excel单元格选中的区域</param>
/// <param name="PicturePath">要插入图片的绝对路径。</param>
public void InsertPicture(Excel.Range rng, Excel._Worksheet sheet, string PicturePath)
{
rng.Select();
float PicLeft, PicTop, PicWidth, PicHeight;
try
{
PicLeft = Convert.ToSingle(rng.Left);
PicTop = Convert.ToSingle(rng.Top);
PicWidth = Convert.ToSingle(rng.Width);
PicHeight = Convert.ToSingle(rng.Height);

  //参数含义:
      //图片路径
      //是否链接到文件
      //图片插入时是否随文档一起保存
      //图片在文档中的坐标位置 坐标
      //图片显示的宽度和高度
sheet.Shapes.AddPicture(PicturePath, Microsoft.Office.Core.MsoTriState.msoFalse, Microsoft.Office.Core.MsoTriState.msoTrue, PicLeft, PicTop, PicWidth, PicHeight);

}
catch(Exception ex)
{
MessageBox.Show("错误:" + ex.Message);
}
}

转载于:https://www.cnblogs.com/guyandianzi/p/7466673.html

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在 C# 使用 NPOI 插入图片Excel 单元格,你可以按照以下步骤操作: 1. 加载 Excel 文件并创建工作簿和工作表对象: ```csharp FileStream fs = new FileStream("test.xlsx", FileMode.Open, FileAccess.ReadWrite); IWorkbook workbook = new XSSFWorkbook(fs); //或者 new HSSFWorkbook(fs) ISheet sheet = workbook.GetSheetAt(0); ``` 2. 创建图片对象并设置其属性: ```csharp byte[] imgBytes = File.ReadAllBytes("image.png"); int pictureIdx = workbook.AddPicture(imgBytes, PictureType.PNG); XSSFDrawing drawing = (XSSFDrawing)sheet.CreateDrawingPatriarch(); XSSFClientAnchor anchor = new XSSFClientAnchor(0, 0, 0, 0, 1, 1, 2, 3); XSSFPicture picture = (XSSFPicture)drawing.CreatePicture(anchor, pictureIdx); ``` 其,`XSSFDrawing` 和 `XSSFClientAnchor` 是 NPOI 的类,用于设置图片在 Excel 的位置和大小。`anchor` 的参数依次为:起始列号、起始行号、结束列号、结束行号、起始列偏移量、起始行偏移量、结束列偏移量、结束行偏移量。 3. 将图片插入到单元格: ```csharp IRow row = sheet.GetRow(0); ICell cell = row.CreateCell(0); cell.SetCellValue("图片插入Excel"); anchor.SetAnchorType(2); picture.Anchor = anchor; ``` 需要注意的是,插入图片单元格必须为空。如果单元格不为空,可以先将单元格的值清空,再插入图片。 4. 保存 Excel 文件: ```csharp fs.Close(); FileStream outFs = new FileStream("test.xlsx", FileMode.Create); workbook.Write(outFs); outFs.Close(); ``` 这样就可以在 Excel 单元格插入图片了。需要注意的是,NPOI 只支持插入 PNG 和 JPEG 格式的图片。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值