Solved

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

Posted on 2013-07-01
13
528 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 45

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 45

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
 
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 45

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
Highfive + Dolby Voice = No More Audio Complaints!

Poor audio quality is one of the top reasons people don’t use video conferencing. Get the crispest, clearest audio powered by Dolby Voice in every meeting. Highfive and Dolby Voice deliver the best video conferencing and audio experience for every meeting and every room.

 
LVL 1

Author Closing Comment

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

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 45

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 45

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 45

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

How to run any project with ease

Manage projects of all sizes how you want. Great for personal to-do lists, project milestones, team priorities and launch plans.
- Combine task lists, docs, spreadsheets, and chat in one
- View and edit from mobile/offline
- Cut down on emails

Join & Write a Comment

A little background as to how I came to I design this code: Around 5 years ago I designed an add-in that formatted Excel files to a corporate standard, applying different cell colours and font type depending on whether the cells contained inputs,…
Improved? Move/Copy Add-in Replacement - How to avoid the annoying, “A formula or sheet you want to move or copy contains the name XXX, which already exists on the destination worksheet.” David Miller (dlmille)  It was one of those days… I wa…
Graphs within dashboards are meant to be dynamic, representing data from a period of time that will change each time the dashboard is updated with new data. Rather than update each graph to point to a different set within a static set of data, t…
This Micro Tutorial demonstrates how to create Excel charts: column, area, line, bar, and scatter charts. Formatting tips are provided as well.

744 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

Need Help in Real-Time?

Connect with top rated Experts

11 Experts available now in Live!

Get 1:1 Help Now