on 2019 Jul 01 11:14 PM
Hello,
I recently upgraded Excel from 32-bit to 64-bit for the performance gains when working with large amounts of data. However, after doing this, my VBA scripts in Excel are no longer working. I get an error on the following line of code:
Set SAPGuiApp = CreateObject("Sapgui.ScriptingCtrl.1")
Error: "ActiveX component can't create object"
From my research, I've seen that there may be a work around by editing the registry. Is this still the best solution?
Excel for Office 365 MSO (16.0.10730.20348) 64-bit
SAP 7.40 Patch 12
Thanks!
Will
Hello Will,
I tried a tiny script to check instantiation of Sapgui.ScriptingCtrl.1 with SAP GUI 7.60 Patch 1 HF 1 and the behaviour is the same.
On Error Resume Next
Set SAPGuiApp = CreateObject("Sapgui.ScriptingCtrl.1")
On Error Goto 0
If IsObject(SAPGuiApp) Then
WScript.Echo "Object Created"
Else
WScript.Echo "Can't Create Object"
End If
Set SAPGuiApp = Nothing
x86 runs without any problems and x64 don't.
Okay, you can find a registry hack here, maybe this solves your problem.
Let us know your results.
Best regards
Stefan
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.
I recently needed to make some older VBA scripts (from Excel 32 bit), work with the newer Excel 64-bit. I am using SAP GUI 7.60 (7600.1.3.1156)
My error was also "ActiveX component can't create object" at this line
Set fns = CreateObject("SAP.Functions")
According to this note, the GUI 7.60 should set the registry keys "Therefore, as of patchlevel 8 of SAP GUI for Windows 7.50 and as of SAP GUI for Windows 7.60, the installation of SAP GUI for Windows automatically writes the respective registry values so that a usage of saprotwr.dll from 64bit processes is possible"
2689304-Usage of SAP GUI Scripting ROT Entry Helper (saprotwr.dll) by 64bit applications
However I found it did not work. I tried to use the registry hack as below, and can confirm that this did fix the problem. My GUID is
{5B076C03-2F26-11CF-9AE5-0800096E19F4}
This step was not necessary - already set, maybe by the GUI 7.60 installer
I will try the installation again with a later 7.60 GUI and a clean Windows 10 installation.
This is a more up-to-date and recent description of the registry change: https://docs.microsoft.com/en-us/windows/win32/com/registering-the-dll-server-for-surrogate-activati...
qurm I also had the same positive result, and I agree everything you saide. About "This step was not necessary - already set, maybe by the GUI 7.60 installer", it's your own previous action ("Add a new key under HKey_Classes_Root\Wow6432Node\AppID\") which automatically added implicitly the OTHER registry key.
In the following two cases, if you create the first key, it will create another one implicitly:
HKEY_CLASSES_ROOT\WOW6432Node\AppID\TEST
-> HKEY_LOCAL_MACHINE\SOFTWARE\Classes\AppID\TEST
HKEY_CLASSES_ROOT\AppID\TEST
-> HKEY_LOCAL_MACHINE\SOFTWARE\Classes\WOW6432Node\AppID\TEST
HKCR and HKLM are somewhat inter-connected, it's better explained here: https://support.microsoft.com/en-us/help/256986/windows-registry-information-for-advanced-users
User | Count |
---|---|
68 | |
9 | |
8 | |
7 | |
7 | |
6 | |
6 | |
6 | |
5 | |
5 |
You must be a registered user to add a comment. If you've already registered, sign in. Otherwise, register and sign in.