LibXL:打开 MS excel 文件时如何强制重新计算公式?

Posted

技术标签:

【中文标题】LibXL:打开 MS excel 文件时如何强制重新计算公式?【英文标题】:LibXL : how to force formulas to recalculate when MS excel file is opened? 【发布时间】:2020-02-24 23:01:32 【问题描述】:

在 MS excel 文件中,用户已设置手动重新计算公式。 在将数据写入文件后,我想强制使用 LibXL 自动重新计算。这有可能吗?

我已搜索文档,但找不到任何相关内容。 在我打开使用 LibXL 创建的文件后,LibreOffice 会自动重新计算公式,但 Microsoft Office 不会。

显示我的代码毫无意义。 LibXL 是否有标志/方法来做到这一点。

在我用 LibXL 完成创建文件并在 MS Office 中打开文件后,我希望公式会自动执行。

注意:我使用的是 php

【问题讨论】:

如果用户强制手动计算,你不觉得数值不正确是他们的问题吗? @Andreas - 用户不知道他们在做什么,公司要求我们在每种情况下自动触发公式。 【参考方案1】:

如果用户第一次打开文件并且用户计算机上没有打开任何窗口,则计算模式在 MS excel 上默认设置为“自动”。但是在打开您的工作簿之前,如果用户以某种方式在他的其他工作簿上激活了手动计算模式,您的文件也将以手动模式打开。

我不确定 PHP 是如何参与其中的。但是要强制自动计算,您可以在文件中添加一个简单的打开事件宏。

Sub Workbook_Open()
 Calculate
End Sub

将其复制到 Visual Basic 窗口中的工作簿对象中。每次打开文件时都会执行此宏。

希望对你有帮助

【讨论】:

感谢重播。 LibXL 无法向 excel 文件添加宏。所以问题是:如何在用户打开它们并执行任何操作(使用 libxl 或 php)之前以编程方式操作 excel 文件。 据我了解,我们这里不是在谈论操纵excel文件,我们是想操纵Excel作为程序的行为。所以这可以用两种方法解决。 Excel选项>公式选项卡中有一种方法可以设置您可以使用Windows组策略修改的计算方法。您可以强制用户计算机将此选项设置为自动。第二种方法可能是创建带有重新计算公式的宏的第二个文件,然后输出最终的 excel 文件。除此之外,快速谷歌搜索列出了一些在 PHP 中将宏包含在 excel 文件中的方法。

以上是关于LibXL:打开 MS excel 文件时如何强制重新计算公式?的主要内容,如果未能解决你的问题,请参考以下文章

提取数据 LibXL C++

Libxl 背景颜色

如何从我的应用程序在MS-Excel或MS-Word - Android中打开excel,doc文件

如何在 iOS 中从 ms-word 或 ms-excel 打开 excel、doc

ruby 使用hombrew-php安装php excel扩展和libxl的brew公式

Microsoft Excel csv文件强制以UTF-8打开[重复]