Solved

how to verify if an item exists in a array using excel vba?

Posted on 2013-07-01
13
531 Views
Last Modified: 2013-07-01
Hi,

I need a code to verify if an item exists in an array. Then if exists do nothing, if doesn't exists then add to the array. Any idea?
0
Comment
Question by:joyacv2
  • 7
  • 6
13 Comments
 
LVL 46

Expert Comment

by:Martin Liss
ID: 39291934
You can use a collection instead, Keys in a collection must be unique and you get error 457 if you try to add a duplicate. So you wouldn't do it this way but here's an example.


Dim MyCollection As New Collection

On Error Resume Next
MyCollection.Add "value 1", "Key 1"
MyCollection.Add "value 2", "Key 1"
If Err.Number = 457 Then
    MsgBox "Key already in collevtion"
End If

Open in new window

MyCollection.Count will be 1 at the end of the code.
0
 
LVL 1

Author Comment

by:joyacv2
ID: 39291938
Hi,

How a collection works, how i refer to an item later? How I know the dimension of the collection? How is different from an array? Thank You
0
 
LVL 46

Expert Comment

by:Martin Liss
ID: 39291943
Collections start at index 1 so this would return "Value 1" using the above code.

MsgBox MyCollection(1)
0
Netscaler Common Configuration How To guides

If you use NetScaler you will want to see these guides. The NetScaler How To Guides show administrators how to get NetScaler up and configured by providing instructions for common scenarios and some not so common ones.

 
LVL 1

Author Comment

by:joyacv2
ID: 39291945
But how is differs from an array?

My problem is that all my codes are in arrays
0
 
LVL 1

Author Comment

by:joyacv2
ID: 39291948
In the code why value 2 gives an error if it's not equal to value 1?
0
 
LVL 46

Accepted Solution

by:
Martin Liss earned 500 total points
ID: 39291953
Collection.Count is the number of items in the collection.

Besides the above which is the normal way of doing things there is also 'Before' and 'After' parameters that can be used if you like to insert values at a particular place in the collection.


This code would return "Value 2" followed by "Value 1" because the second Add tells VBA to insert the item before "Key 1"

Dim MyCollection As New Collection

On Error Resume Next
MyCollection.Add "value 1", "Key 1"
MyCollection.Add "value 2", "Key 2", "Key 1" 
If Err.Number = 457 Then
    MsgBox "Key already in collevtion"
End If

MsgBox MyCollection(1)
MsgBox MyCollection(2)

Open in new window


To insert after you do

MyCollection.Add "value 2", "Key 2", "Key 1" ,, "key value to insert after"
0
 
LVL 1

Author Closing Comment

by:joyacv2
ID: 39291956
EXCELLENT, THANK YOU FOR YOUR RESPONSE
0
 
LVL 46

Expert Comment

by:Martin Liss
ID: 39291957
In the code why value 2 gives an error if it's not equal to value 1?
Because it checks the keys and not the values, so if you want to check for duplicate values make the key the same as the value. In other words

Dim MyCollection As New Collection

On Error Resume Next
MyCollection.Add "value 99", "value 99"
MyCollection.Add "value 1", "value 1"
MyCollection.Add "value 1", "value 1"
If Err.Number = 457 Then
    MsgBox "Key already in collection"
End If

Open in new window


In case it's not clear, the generalized code is

MyCollection.Add <some value>,<some key that must be a string>
0
 
LVL 46

Expert Comment

by:Martin Liss
ID: 39291959
You're welcome and I'm glad I was able to help.

Marty - MVP 2009 to 2013
0
 
LVL 46

Expert Comment

by:Martin Liss
ID: 39291962
BTW one more example. You don't have to use a key so this is perfectly valid and you wind up with 2 items in the collection.

Dim MyCollection As New Collection

On Error Resume Next

MyCollection.Add "value 1"
MyCollection.Add "value 1"

Open in new window

0
 
LVL 1

Author Comment

by:joyacv2
ID: 39291963
PERFECT, SO USING THE SAME SOLVE MY PROBLEM!
0
 
LVL 46

Expert Comment

by:Martin Liss
ID: 39291986
There's also a more advanced type of collection called a Dictionary but I don't have much experience with them.
0
 
LVL 1

Author Comment

by:joyacv2
ID: 39291991
for me, collection is new, i am working right with it, and works perfect!
0

Featured Post

Netscaler Common Configuration How To guides

If you use NetScaler you will want to see these guides. The NetScaler How To Guides show administrators how to get NetScaler up and configured by providing instructions for common scenarios and some not so common ones.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Drop Down List with Unique/Distinct Values (Part II - ComboBox or ListBox and Data Validation List Bonus!) David Miller (dlmille) Intro This article focuses on delivering unique, sorted lists to list objects (e.g., ComboBox, ListBox) and Dat…
Workbook link problems after copying tabs to a new workbook? David Miller (dlmille) Intro Have you either copied sheets to a new workbook, and after having saved and opened that workbook, you find that there are links back to the original sou…
This Micro Tutorial will demonstrate in Google Sheets how to use the HYPERLINK function to create live links inside your spreadsheet.
This Micro Tutorial will demonstrate how to use a scrolling table in Microsoft Excel using the INDEX function.

770 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question