Legacy macros running slow in Excel 2010

emanresu

New Member
Joined
Oct 19, 2006
Messages
13
Hi,
I have inherited support for a suite of Excel 2003 spreadsheets with complicated macros which run fine on XP. Having been tasked to test them on Windows 7 with Office 2010, I have not converted them as they are run by several sites globally who may not upgrade to Office 2010 at the same time. Hence they run in compatibility mode which in general is fine.

However, certain macros are veeeery slow and to the user would look like the app has hung. In debug I have found that the macro takes 10 minutes plus whenever it hits any of the following code:
Code:
With Application
     .Calculation = xlAutomatic
     .MaxChange = 0.001
End With

ActiveWorkBook.PrecisionAsDisplayed = False

It goes slow on each of the three 'lines' so it seems that it is actually doing an auto calc each time!

Is there some configuration I can do to prevent this? Setting auto calc to Manual didn't help and anyway I loose things, like data validation, when I save it in Excel 2010.

Thanks for any help you can give.
 

Excel Facts

Format cells as date
Select range and press Ctrl+Shift+3 to format cells as date. (Shift 3 is the # sign which sort of looks like a small calendar).
To give a better idea of the problem I'd like to post some more code but there is a lot of it!

Is it possible to attach a document on this forum?
 
Upvote 0
For completeness sake, here is the solution:

Excel 2003 differs from 2007/2010 in that the later versions have a new smart calculation engine, so it works pretty much differently from before.

The code written by the original author had several of those "Application.Calculation" commands.

I discovered that with the new calculation engine I didn't need any of those commands!

All I did in the end was to strip them all out and it worked like a dream.
 
Upvote 0
For completeness sake... if anyone is reading this.

I have come across the same problem and it took me ages to figure it out what the solution is to it. Apparently not many forums mention my solution. In the end I have just laughed as all I had to do (instead of skimming my code with some of being 300 to 500 lines long) was this:

Application.PrintCommunication = False

the bleeding printer com app. What was I thinking :).

Anyway if it helps don't forget to turn it back on again at the end of your code (True), otherwise your excel will not print.

Have a good day...

Alex
 
Last edited:
Upvote 0

Forum statistics

Threads
1,224,586
Messages
6,179,726
Members
452,939
Latest member
WCrawford

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top