Solved

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

Posted on 2013-07-01
13
533 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
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 7
  • 6
13 Comments
 
LVL 47

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 47

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
Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
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 47

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 47

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 47

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 47

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 47

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

Technology Partners: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

Question has a verified solution.

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

Suggested Solutions

This article will guide you to convert a grid from a picture into Excel format using Microsoft OneNote and no other 3rd party application.
You need to know the location of the Office templates folder, so that when you create new templates, they are saved to that location, and thus are available for selection when creating new documents.  The steps to find the Templates folder path are …
This Micro Tutorial demonstrates how to create Excel charts: column, area, line, bar, and scatter charts. Formatting tips are provided as well.
This Micro Tutorial demonstrate the bugs in Microsoft Excel for Mac with Pivot Charts.

735 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