VBA Array Subscript error

nmounir

Board Regular
Joined
Oct 16, 2020
Messages
107
Office Version
  1. 365
Platform
  1. Windows
Hello Everyone,

I am new to VBA and was trying to write a VBA array code for some reason I keep getting asubscript out of range error
I would like VBA to calculate target sales in column E to be equal to the current SalesAmounts X 2 which in column D.

Option Explicit

Sub Arrytraining()

Dim SalesAmounts() As Variant
Dim i As Long, Dimension1 As Long
Dim SalesTraget() As Variant

SalesAmounts = Range("D2", Range("D2").End(xlDown))
Dimension1 = UBound(SalesAmounts, 1)
ReDim SalesTarget(1 To Dimension1)
For i = 1 To Dimension1
SalesAmounts(i, 1) = SalesTarget(i, 1) * 2 (This is where the error is)

Next i

Range("E2", Range("E2").Offset(Dimension1 - 1, 1)).Value = SalesTarget


End Sub

Your help is much appreciated
 

Attachments

  • Image 1.PNG
    Image 1.PNG
    10.4 KB · Views: 9
  • Image 2.PNG
    Image 2.PNG
    14.5 KB · Views: 9

Excel Facts

Round to nearest half hour?
Use =MROUND(A2,"0:30") to round to nearest half hour. Use =CEILING(A2,"0:30") to round to next half hour.
You are getting that error because SalesTarget array is a one dimensional array and you are trying to access it like a two dimensional array.

Try like this : SalesTarget(i)

The rest of that line of code doesn't make much sense though!
 
Upvote 0
In addition to what FormR said
column E to be equal to the current SalesAmounts X 2
Same line should be
And last line as well
VBA Code:
Sub Arrytraining()

    Dim SalesAmounts() As Variant
    Dim i As Long, Dimension1 As Long
    Dim SalesTraget() As Variant
    SalesAmounts = Range("D2", Range("D2").End(xlDown))
    Dimension1 = UBound(SalesAmounts, 1)
    ReDim SalesTarget(1 To Dimension1)
    For i = 1 To Dimension1
        SalesTarget(i) = SalesAmounts(i, 1) * 2    ' ('This is where the error is)
    Next i
    Range("E2", Range("E2").Offset(Dimension1 - 1, 1)).Value = Application.Transpose(SalesTarget)
End Sub
 
Upvote 0
Correction
VBA Code:
 Range("E2", Range("E2").Offset(Dimension1 - 1)).Value = Application.Transpose(SalesTarget)
 
Upvote 0
Solution
It
In addition to what FormR said

Same line should be
And last line as well
VBA Code:
Sub Arrytraining()

    Dim SalesAmounts() As Variant
    Dim i As Long, Dimension1 As Long
    Dim SalesTraget() As Variant
    SalesAmounts = Range("D2", Range("D2").End(xlDown))
    Dimension1 = UBound(SalesAmounts, 1)
    ReDim SalesTarget(1 To Dimension1)
    For i = 1 To Dimension1
        SalesTarget(i) = SalesAmounts(i, 1) * 2    ' ('This is where the error is)
    Next i
    Range("E2", Range("E2").Offset(Dimension1 - 1, 1)).Value = Application.Transpose(SalesTarget)
End Sub


[/QUOTE]
It worked perfectly but I am a bit puzzled why we had to use the transpose function if the size of the array hasn't changed ? I did a similar  code without using the transpose and it worked fine so i am confused why it didn't work the first time and it did on the second time with transpose.  

here is the code I used in the second time but there was an if condition. it is a very similar example where we want to increase the salary of those earning less than $30,000 (in column D) by double the salary and spit out the result in column E.   

Any idea why the second code with If condition worked fine without tranpose and without i alone?

Sub TestDynamicArraySalaries()

Dim SalaryList As Variant
Dim i As Byte

    Sheet1.Activate
    SalaryList = Range("D2", Range("D1").End(xlDown)).Value
    For i = 1 To UBound(SalaryList, 1)
    If SalaryList(i, 1) <= 30000 Then
        SalaryList(i, 1) = SalaryList(i, 1) * 2
        
    End If
    Next i
    
    Range("E2").Resize(UBound(SalaryList, 1)) = SalaryList
    
End Sub
 

Attachments

  • Image 1.PNG
    Image 1.PNG
    17.7 KB · Views: 7
  • image 2.PNG
    image 2.PNG
    11.4 KB · Views: 7
Upvote 0
See in the debugger
Notice that SalesTarget one dimensional array
While SalaryList tow dimensional array
 
Upvote 0
You are very welcome
And thank you for the feedback
Be Happy and safe
 
Upvote 0

Forum statistics

Threads
1,223,240
Messages
6,170,951
Members
452,368
Latest member
jayp2104

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