首页 > 解决方案 > 使用 OpenXml 嵌入 Excel 加载项

问题描述

我的团队正在开发适用于 Excel 的 Office 365 加载项,作为项目的一部分,我们正在通过 GraphAPI 创建 Excel 文档,最终目标是为文档设置加载项。在通过 GraphAPI 复制文档之前,我们使用 .NET OpenXml 库来创建文档。

我们无法找到很多关于如何通过 OpenXml 设置加载项的资源,也无法让任何东西正常工作。我们尝试的最后一件事是复制我们在此处找到的示例,但无法使其正常工作。有谁知道如何使用 OpenXml 库设置加载项?

注意:加载项已在 Office 加载项商店中,并且我们拥有 AppSource ID 等信息。

谢谢!

标签: exceloffice-jsopenxml

解决方案


实际上,我们即将发布一个围绕此场景的新示例。该示例展示了如何使用 OOXML 创建 Excel 文档、嵌入加载项,然后将文件上传到 OneDrive。它还会创建一个链接到该文件的团队聊天。

您可以在此处试用示例:在 Microsoft Teams 的电子表格中打开您网站的数据

或者就 PR 给我们反馈:https ://github.com/OfficeDev/PnP-OfficeAddins/pull/197

要回答有关如何嵌入加载项的问题,您需要创建一个 Web 扩展部分。我在这里复制了相关代码。请注意,这与您已经查看过的Office-OOXML-EmbedAddin示例中的代码相同。我们将它重新用于新样本。您可以更改 CUSTOM MODIFICATION 部分,以便在加载项打开时提供您想要的任何自定义属性。

// Embeds the add-in into a file of the specified type.
private void EmbedAddin(SpreadsheetDocument spreadsheet)
{
   spreadsheet.DeletePart(spreadsheet.WebExTaskpanesPart);
   var webExTaskpanesPart = spreadsheet.AddWebExTaskpanesPart();
   CreateWebExTaskpanesPart(webExTaskpanesPart);
}

// Adds child parts and generates content of the specified part.
private void CreateWebExTaskpanesPart(WebExTaskpanesPart part)
{
   WebExtensionPart webExtensionPart1 = part.AddNewPart<WebExtensionPart>("rId1");
   GenerateWebExtensionPart1Content(webExtensionPart1);

   GeneratePartContent(part);
}

// Generates content of webExtensionPart1.
private void GenerateWebExtensionPart1Content(WebExtensionPart webExtensionPart1)
{
   // Add web extension containg Id for Script Lab add-in
   We.WebExtension webExtension1 = new We.WebExtension() { Id = "{635BF0CD-42CC-4174-B8D2-6D375C9A759E}" };
   webExtension1.AddNamespaceDeclaration("we", "http://schemas.microsoft.com/office/webextensions/webextension/2010/11");

   // Add store information for Script Lab add-in
   We.WebExtensionStoreReference webExtensionStoreReference1 = new We.WebExtensionStoreReference() { Id = "wa104380862", Version = "1.1.0.0", Store = "en-US", StoreType = "OMEX" };
   We.WebExtensionReferenceList webExtensionReferenceList1 = new We.WebExtensionReferenceList();

   We.WebExtensionPropertyBag webExtensionPropertyBag1 = new We.WebExtensionPropertyBag();

   // Add the property that makes the taskpane visible.
   We.WebExtensionProperty webExtensionProperty1 = new We.WebExtensionProperty() { Name = "Office.AutoShowTaskpaneWithDocument", Value = "true" };
   webExtensionPropertyBag1.Append(webExtensionProperty1);

   // CUSTOM MODIFICATION BEGIN
   // Add the property that specifies the snippet to import.
   string snippetToImportValue = string.Format("{{\"type\":\"gist\",\"id\":\"{0}\"}}", "{72189570-AE11-4207-9DEE-C8BDE4B83188}");
   We.WebExtensionProperty webExtensionProperty2 = new We.WebExtensionProperty() { Name = "SnippetToImport", Value = snippetToImportValue };
   webExtensionPropertyBag1.Append(webExtensionProperty2);
   // CUSTOM MODIFICATION END

   We.WebExtensionBindingList webExtensionBindingList1 = new We.WebExtensionBindingList();

   We.Snapshot snapshot1 = new We.Snapshot();
   snapshot1.AddNamespaceDeclaration("r", "http://schemas.openxmlformats.org/officeDocument/2006/relationships");

   webExtension1.Append(webExtensionStoreReference1);
   webExtension1.Append(webExtensionReferenceList1);
   webExtension1.Append(webExtensionPropertyBag1);
   webExtension1.Append(webExtensionBindingList1);
   webExtension1.Append(snapshot1);

   webExtensionPart1.WebExtension = webExtension1;
}

// Generates content of part.
private void GeneratePartContent(WebExTaskpanesPart part)
{
   Wetp.Taskpanes taskpanes1 = new Wetp.Taskpanes();
   taskpanes1.AddNamespaceDeclaration("wetp", "http://schemas.microsoft.com/office/webextensions/taskpanes/2010/11");

   Wetp.WebExtensionTaskpane webExtensionTaskpane1 = new Wetp.WebExtensionTaskpane() { DockState = "right", Visibility = true, Width = 350D, Row = (UInt32Value)4U };

   Wetp.WebExtensionPartReference webExtensionPartReference1 = new Wetp.WebExtensionPartReference() { Id = "rId1" };
   webExtensionPartReference1.AddNamespaceDeclaration("r", "http://schemas.openxmlformats.org/officeDocument/2006/relationships");

   webExtensionTaskpane1.Append(webExtensionPartReference1);

   taskpanes1.Append(webExtensionTaskpane1);

   part.Taskpanes = taskpanes1;
}

推荐阅读