gpt4 book ai didi

vba - 如何使在 32 位 Excel 2016 上编写的宏在 64 位 Excel 2016 上工作

转载 作者:行者123 更新时间:2023-12-04 22:32:15 26 4
gpt4 key购买 nike

宏最初是在 64 位 excel 2016 版本(来自 Office 365)上创建的,但我一直在我的 32 位 2016 版本(来自 Office 365)中处理它。该宏在我的 32 位计算机上完美运行。但是,我正在为其工作的人正在使用 64 位版本的 Excel 2016,他们说它一直在为他们崩溃,但它是不一致的,一直在不同的地方崩溃,甚至偶尔会正常运行。该代码不包含任何声明语句或 long,因此我不确定为什么会发生这种情况或该怎么做。任何有关如何解决此问题或问题所在的帮助将不胜感激。谢谢你。下面包含一个已经崩溃的代码副本。

Sub Formulas()

Dim rows As String

rows = CStr(Range("Sheet1!C31").Value)

Range("Sheet2!M2:M" & rows).Formula = "=((F2*1000)-(Sheet1!$C$13*(COS(2*PI()*(Sheet1!$C$15/360)))))*-1"
Range("Sheet2!N2:N" & rows).Formula = "=IF(G2<0,0,((G2+Sheet1!$C$19+Sheet1!$C$21)*Sheet1!$C$17))"
Range("Sheet2!O2:O" & rows).Formula = "=M2+N2"
Range("Sheet2!P2:P" & rows).Formula = "=O2/Sheet1!$C$23"
Range("Sheet2!Q2:Q" & rows).Formula = "=IF(OR(P2>(Sheet1!$C$25),P2<(Sheet1!$C$26)),1,0)"
Range("Sheet2!R2:R" & rows).Formula = "=IF(H2>0,1,0)"
Range("Sheet2!S2:S" & rows).Formula = "=IF(AND(Q2=1),(R2=1)*1,0)"
Range("Sheet2!B17").Formula = "=1-(SUM(S:S)/SUM(R:R))"
Range("Sheet1!C28") = Range("Sheet2!B17")

'Do While Not IsEmpty(ActiveCell.Value)
' Range("Sheet2!M" & CStr(ActiveCell.Row)).EntireRow.Delete
'Loop


End Sub

我对 vba 和宏还很陌生,所以如果有人能指出代码的哪些方面在 64 位中不兼容,甚至建议如何修复它,我将非常感激。谢谢你。

最佳答案

代码最终很好。我们必须在此处的“注册表信息”部分下进行注册表破解:https://support.microsoft.com/en-us/help/3085435/august-8-2017-update-for-excel-2016-kb3085435

关于vba - 如何使在 32 位 Excel 2016 上编写的宏在 64 位 Excel 2016 上工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51861236/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com