- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在考虑用直接使用 Office XML 格式的代码替换(非常)大量的 Office 自动化代码。我刚刚开始,但我已经担心这是一项太大的任务。
我将处理 Word、Excel 和 PowerPoint。到目前为止,我只看过 Word 和 Excel。看起来 Word 文档应该相当容易操作,但 Excel 工作簿看起来就像一场噩梦。例如...
在 Word 中,看起来您只需删除相应的“w:p”标签即可删除段落。但是,提供的用于在 Excel 中删除一行的代码片段需要大约 150 行代码(!)。
Excel代码这么大的原因是删除一行意味着更新所有后续行的行索引,修复“共享字符串”表等。 根据顶部的注释,代码片段甚至不完整,因为它不会处理包含表格的工作簿(我可以接受)。
我不清楚的是这是否是示例代码的唯一限制。例如,如果工作簿包含数据透视表,也会有问题吗?还是引用同一工作表中数据的图表?或者一些命名范围?您是否还必须更新引用行索引已更改的行的任何单元格(等)的公式?
[更不用说“计算链”了,(谢天谢地)我认为你可以简单地删除它,因为它只是一个可以重建的 chache。]
这就是我的问题,尽管它是毛茸茸的。做一些像正确删除一行这样简单的事情,你需要付出多大的努力?这是一项不可逾越的任务吗?
此外,如果 Excel 或 Word 或 PowerPoint 存在其他类似问题,我很想现在就了解这些问题,以免我浪费太多时间走上死胡同。谢谢。
最佳答案
在使用 Open XML SDK 2.0 近两年之后,我可以说,完成看似微不足道的任务可能需要花费数小时甚至数天才能弄清楚如何正确地完成。例如,删除 Excel 行应该相当简单易行,对吗?不,因为您不仅需要代码来删除行,而且还必须更新所有行索引、更新任何合并的单元格引用、更新超链接引用等。我们的内部删除方法接近 500 行代码来删除一行,我相信我们也没有考虑到所有的情况。
我最大的提示是缺乏关于如何完成最常见任务的文档。 MSDN Open XML SDK 上的部分非常有限,无论何时您需要做任何复杂的事情,您都需要靠自己。我必须阅读 Open XML标准很多,以确定某些元素的含义以及它们应该如何实现,因为我在网上几乎找不到。
另一个具有挑战性的部分是,如果您在一个元素不属于它的位置插入一个元素或在一个元素上放置一个无效的属性,当您尝试打开它时,您将得到一个损坏的文件。大多数情况下,您不会获得有关导致错误的原因的任何信息,您必须查看 Open XML 标准规范以了解您做错了什么。
如果您需要快速完成将 Office 自动化代码转换为 Open XML 的周转时间,并且您所做的并不是真正的基础,那么我会说通过。如果您有时间和耐心阅读 Word、Excel 和 PowerPoint XML 结构并熟悉它们之间的关系,那么我建议您继续阅读。在我看来,这确实是对这些办公文档进行非常精细控制的唯一方法,但是当您开始时,将会有一个很好的学习曲线。
哦,只是为了好玩,这里是向 Excel 添加注释需要多少代码 cell .
关于ms-office - 使用 Office "open"XML - 这有多难?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9004848/
我对 Office Scripts 和 Office Lab 感到困惑。 两者都可以在 Excel 中运行 javascript,但似乎无法在它们中共享代码。 对于 Office 脚本,一些代码如 f
如果我们加载一个引用 office.js 的网页在 Office 客户端之外,我们会收到警告:Office.js is loaded outside of Office client . 这些信息很有
我试图找到一种将 Outlook 插件发布到办公商店的方法。但我发现我们只能发布 Office 应用程序,而不能发布 Office 商店的加载项。因此我想知道 Office 应用程序和 Office
我想使用 Ooxml 以编程方式自定义“Heading1”和“Heading2”样式通过 office.js Visual Studio 代码中的库。我已经搜索过谷歌和许多文档,但仍然没有得到任何内容
我想使用 Microsoft.Office.Interop.Excel 从 XLS 文件中提取一些数据。我安装了 Visual Studio 2010 和 Office 开发人员工具。但是,我在 va
最近,Microsoft 推出了 Office 插件架构,该架构允许开发远程托管并在 Office 内的 IFrame 中运行的插件。我读了很多文章,试图了解这个架构是否是 VSTO 的替代品,或者它
我开发了一个将数据导入 Microsoft Excel 的应用程序。 我使用 VS2005 + .NET 2.0,并且我的计算机上安装了 Microsoft Office 2007 (Office 1
是否有推荐的方法(包、框架等)来设置 Office 加载项的自动化端到端测试。我对测试的所有搜索都导致侧加载应用程序和手动测试。 例如:https://dev.office.com/docs/add-
我们正在为 Excel 和 Word 开发 javascript Office 插件。我们的用户将使用 Office Desktop 和 Office Online。 当用户在加载项中创建新记录时,我
我在电子表格上有一个表格,我想删除所有现有数据。我使用下面的代码,除非表格已经是空的。 // Get the row count let rowCount = table.getRangeBetwee
所以我正在尝试开始开发 Office 365 加载项(以前的 Office 应用程序),我想知道 Office 在呈现您的应用程序时使用什么浏览器或浏览器引擎。我尝试使用 JavaScript 的 n
我正在寻找一些关于在 网上商店 上托管我们当前托管应用程序的更新版本的信息。 我的查询是,我们现有版本的应用程序说的 list 文件 版本。 1.0 托管在网上商店指向源位置(天蓝色 网站)说 mya
在我们的组织中,我们构建了一个 Office 加载项。现在我们想在我们的加载项中添加打印功能。谁能帮助我如何使用 Office javascript API 添加打印功能。 最佳答案 Office.J
我有兴趣了解有关 Microsoft Office Communicator 的更多信息IM 客户端,以及它如何确定您的存在(即您是在计算机旁还是不在)。任何人都可以向我指出解释这一点的教程或 API
问题: 我有两个电子表格,每个电子表格都有不同的用途,但包含一个特定的数据,这两个电子表格中的数据需要相同。这条数据(其中一列)在电子表格 A 中更新,但也需要在电子表格 B 中更新。 目标: 以某种
可在此处获得office.js的正式版本: https://appsforoffice.microsoft.com/lib/1/hosted/office.js 它在代码中包含以下几行: window
不久前我有了一个发现。只需按照以下步骤操作: 在 Office 2003 中创建一个 .doc/.xls/.ppt 文件。在其中保留一些测试数据并关闭该文件。现在重命名该文件以将其文件扩展名更改为随机
姓名:来自:file:///D:/Samples/TestUpdatedVersion/bin/Debug/TestUpdatedVersion.vsto 无法安装自定义,因为当前已安装另一个版本并且
已结束。此问题正在寻求书籍、工具、软件库等的推荐。它不满足Stack Overflow guidelines 。目前不接受答案。 我们不允许提出寻求书籍、工具、软件库等推荐的问题。您可以编辑问题,以便
我对使用 Office 2007 在 2007 之前的二进制格式(.doc、.xls、.ppt)和新的 Office Open XML 格式(.docx、.xlsx、.pptx)之间进行转换很感兴趣
我是一名优秀的程序员,十分优秀!