Solved

Get key by idex from a ordered dictionary

Posted on 2006-10-24
8
4,479 Views
Last Modified: 2008-01-09
How can I retrieve the key by using the index?

I can retrieve the value by index like: oOrderedDictionary[0].toString()

Is there something similair for a key value?
(I believe a sortedlist has a GetKey() method, but the ordered dictionary does not?)
0
Comment
Question by:Kai77
  • 5
  • 3
8 Comments
 
LVL 9

Expert Comment

by:jonorossi
ID: 17795792
Have you tried using the TryGetValue method?
0
 

Author Comment

by:Kai77
ID: 17795845
I am using ASP.net 2.0 and intellisense does not say OrderDictionary has a TryGetValue method
0
 
LVL 9

Expert Comment

by:jonorossi
ID: 17795890
Is there a reason you are using System.Collections.Specialized.OrderedDictionary instead of System.Collections.Generic.Dictionary<TKey,TValue>
0
Migrating Your Company's PCs

To keep pace with competitors, businesses must keep employees productive, and that means providing them with the latest technology. This document provides the tips and tricks you need to help you migrate an outdated PC fleet to new desktops, laptops, and tablets.

 

Author Comment

by:Kai77
ID: 17795986
from what i undestand an ordered dictionary the sort order is ordered by the order in which you addes key-value pairs. Does the generic.dictionary do the same?
0
 

Author Comment

by:Kai77
ID: 17796028
I just took a quick look at the Generic.Dictionary .

I believe the TryGetValue needs you to enter a key and will return a value based on that key. What I need is to enter a index and get the key.
0
 
LVL 9

Expert Comment

by:jonorossi
ID: 17796034
If you require that the dictionary be sorted then you should use the generic SortedDictionary:

System.Collections.Generic.SortedDictionary<TKey, TValue>
0
 
LVL 9

Expert Comment

by:jonorossi
ID: 17796213
I see what you are after now. I can't seem to find what you are after in any of the collections built into .NET. For some reason none of them allow you to get the key by an index.
0
 
LVL 9

Accepted Solution

by:
jonorossi earned 500 total points
ID: 17796543
The reason you can't get the key by index with the SortedDictionary is because it is implemented as a binary tree. However, I am not sure why Microsoft didn't add a method to get the Key by index with the OrderedDictionary. Even the OrderedDictionaryKeyValueCollection which you get by going .Keys doesn't have a method to get out a key.

I was thinking get out the OrderedDictionaryKeyValueCollection from .Keys and enumerate the number of times to get to the index. But the GetEnumerator is declared internal so you can't use a foreach.

The only solution I can see is to build your own dictionary either from scratch or inherited from one of the .NET ones. Or try to get one off the internet. Or if you don't need it to be ordered you'd be able to use one of the .NET collections.

This one by Marc Clifton is pretty good http://www.codeproject.com/csharp/GenericKeyedList.asp
0

Featured Post

Efficient way to get backups off site to Azure

This user guide provides instructions on how to deploy and configure both a StoneFly Scale Out NAS Enterprise Cloud Drive virtual machine and Veeam Cloud Connect in the Microsoft Azure Cloud.

Question has a verified solution.

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

In order to hide the "ugly" records selectors (triangles) in the rowheaders, here are some suggestions. Microsoft doesn't have a direct method/property to do it. You can only hide the rowheader column. First solution, the easy way The first sol…
The article shows the basic steps of integrating an HTML theme template into an ASP.NET MVC project
A short tutorial showing how to set up an email signature in Outlook on the Web (previously known as OWA). For free email signatures designs, visit https://www.mail-signatures.com/articles/signature-templates/?sts=6651 If you want to manage em…

823 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