I’m surprised at how hard this has been to do but I imagine it’s a quick fix so I will ask here (searched google and documentation but neither helped). I have some code that adds items to a collection using keys. When I come across a key that already exists in the collection, I simply want to set it by adding a number to the current value.
Here is the code:
If CollectionItemExists(aKey, aColl) Then 'If key already has a value
'add value to existing item
aColl(aKey).Item = aColl(aKey) + someValue
Else
'add a new item to the collection (aka a new key/value pair)
mwTable_ISO_DA.Add someValue, aKey
End If
The first time I add the key/value pair into the collection, I am adding an integer as the value. When I come across the key again, I try to add another integer to the value, but this doesn’t work. I don’t think the problem lies in any kind of object mis-match or something similar. The error message I currently get is
Runtime Error 424: Object Required
You can’t edit values once they’ve been added to a collection. So this is not possible:
Instead, you can take the object out of the collection, edit its value, and add it back.
This is a bit tedious, but place these three lines in a Sub and you’re all set.
Collections are more friendly when they are used as containers for objects (as opposed to containers for “primitive” variables like integer, double, etc.). You can’t change the object reference contained in the collection, but you can manipulate the object attached to that reference.
On a side note, I think you’ve misunderstood the syntax related to
Item. You can’t say:aColl(aKey).Item. The right syntax isaColl.Item(aKey), or, for short,aColl(aKey)sinceItemis the default method of the Collection object. However, I prefer to use the full, explicit form…