Can this simple VBA code be speeded up?

Dobo_Bobo

New Member
Joined
Jan 24, 2018
Messages
31
Please can someone help me improve my VBA code below?

I'm teaching myself VBA and I've written a macro that works but I want to learn how to improve the code so the macro runs quicker. One part of the code that is slow is a creation of a temporary list that needs to be created on a temporary sheet, once the macro is completed the sheet has to deleted, so I can't store the list anywhere.


When the macro runs, the strings are entered one at a time and it takes a while to complete the long list. I've searched the web and I can't find anything to speed up this part, the quickest way I've found is using 'Step Into' on the VBA editor by quickly pressing F8. Pressing F8 really quickly makes this part of the macro run really fast but of course this isn't a viable option.


Below is an extract (S1 is the list's heading):


'In column S this list is created
Range("S1") = "Task Type"
Range("S2") = "Approval"
Range("S3") = "Approval"
Range("S4") = "Approval"
Range("S5") = "Approval"
Range("S6") = "Approval"
Range("S7") = "Approval"
Range("S8") = "Approval"
Range("S9") = "Approval"
Range("S10") = "Approval"
Range("S11") = "Task"
Range("S12") = "Task"
Range("S13") = "Task"
Range("S14") = "Task"
Range("S15") = "Task"
Range("S16") = "Task"
Range("S17") = "Task"
Range("S18") = "Task"
Range("S19") = "Task"


If anyone can teach me a quicker way I will really appreciate it and I will return to give thanks!
 

Excel Facts

Workdays for a market open Mon, Wed, Friday?
Yes! Use "0101011" for the weekend argument in NETWORKDAYS.INTL or WORKDAY.INTL. The 7 digits start on Monday. 1 means it is a weekend.
You could combine each same string like this:

Code:
Range("S1") = "Task Type"
Range("S2:S10") = "Approval"
Range("S11:S19") = "Task"
 
Upvote 0
You could combine each same string like this:
Code:
Range("S1") = "Task Type" Range("S2:S10") = "Approval" Range("S11:S19") = "Task"

D'oh! I feel dumb for no thinking of that, I was trying all sorts I found on the web!

Many thanks for your help dreid1011!!! I've tested it out and it works a treat. I've also tried it with the code below that I've just discovered from the web and it speeds it up just that little bit more. But your code was exactly what I needed.

Thank you! :)

Code:
Sub InsertText()

  
 Application.Calculation = xlCalculationManual
 Application.ScreenUpdating = False
 Application.DisplayStatusBar = False
 Application.EnableEvents = False
  
  
 Range("S1") = "Task Type"
 Range("S2:S10") = "Approval"
 Range("S11:S19") = "Task"
  
  
 Application.EnableEvents = True
 Application.DisplayStatusBar = True
 Application.ScreenUpdating = True
 Application.Calculation = xlCalculationAutomatic
  
  

 End Sub
 
Last edited:
Upvote 0

Forum statistics

Threads
1,223,230
Messages
6,170,883
Members
452,364
Latest member
springate

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