如何解决使用 C# openXml 在 Excel 文件中插入图像
我在 C# 中创建了一个函数来处理 azure 函数,但一开始我收到了这条消息:
System.Runtime.InteropServices.COMException (0x80040154): Retrieving the COM class factory for component with CLSID {00024500-0000-0000-C000-000000000046} Failed due to the following error: 80040154 Class not registered (Exception from HRESULT: 0x80040154 (REGDB_E_CLASSNOTREG)).
在互联网上看,它说这是因为 Azure Function 不能与 Excel Interop dll 一起使用,而实现这一点的方法是使用 OpenXml SDK,所以去创建了一个 OpenXml 方法:
public static void AddImage(string filepath,string imagepath)
{
using (SpreadsheetDocument spreadsheet = SpreadsheetDocument.Open(filepath,true))
{
WorkbookPart wb = spreadsheet.WorkbookPart;
string sheetName = "sheet2";
string relId = wb.Workbook.Descendants<Sheet>().First(s => sheetName.Equals(s.Name)).Id;
WorksheetPart wp = (WorksheetPart) wb.GetPartById(relId);
DrawingsPart drawingsPart1 = wp.AddNewPart<DrawingsPart>();
ImagePart imagePart = drawingsPart1.AddImagePart(ImagePartType.Gif);
using (FileStream stream = new FileStream(imagepath,FileMode.Open))
{
imagePart.FeedData(stream);
}
GenerateDrawingsPart1Content(drawingsPart1,drawingsPart1.GetIdOfPart(imagePart));
Worksheet worksheet = wp.Worksheet;
Drawing drawing1 = new Drawing() { Id = wp.GetIdOfPart(drawingsPart1) };
worksheet.Append(drawing1);
spreadsheet.Close();
}
}
一切顺利,直到他:
DrawingsPart drawingsPart1 = wp.AddNewPart<DrawingsPart>();
现在我不断收到此错误:
"Only one instance of the type is allowed for this parent."
有什么修复错误的建议吗?除了在 Azure Functions 中使用 OpenXml 或 Excel Interop 之外,还有其他方法可以在函数中制作“在 excel 上插入图像”吗?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。