290

How can I get the dictionary value by a key on a function?

My function code (and the command I try doesn't work):

static void XML_Array(Dictionary<string, string> Data_Array)
{
    String xmlfile = Data_Array.TryGetValue("XML_File", out value);
}

My button code:

private void button2_Click(object sender, EventArgs e)
{
    Dictionary<string, string> Data_Array = new Dictionary<string, string>();
    Data_Array.Add("XML_File", "Settings.xml");

    XML_Array(Data_Array);
}

I want on the XML_Array function the variable to be:

string xmlfile = "Settings.xml":
Peter Mortensen
  • 30,030
  • 21
  • 100
  • 124
Matei Zoc
  • 3,341
  • 3
  • 14
  • 15

11 Answers11

381

It's as simple as this:

String xmlfile = Data_Array["XML_File"];

Note that if the dictionary doesn't have a key that equals "XML_File", that code will throw an exception. If you want to check first, you can use TryGetValue like this:

string xmlfile;
if (!Data_Array.TryGetValue("XML_File", out xmlfile)) {
   // the key isn't in the dictionary.
   return; // or whatever you want to do
}
// xmlfile is now equal to the value
Blorgbeard
  • 97,316
  • 47
  • 222
  • 267
121

Just use the key name on the dictionary. C# has this:

 Dictionary<string, string> dict = new Dictionary<string, string>();
 dict.Add("UserID", "test");
 string userIDFromDictionaryByKey = dict["UserID"];

If you look at the tip suggestion:

Enter image description here

Peter Mortensen
  • 30,030
  • 21
  • 100
  • 124
FrenkyB
  • 5,826
  • 13
  • 61
  • 102
  • 6
    It throws an exception if the key does not exist. That is why other people's answers suggest that you should use TryGetValue. – Ladislav Ondris Jul 31 '18 at 10:38
  • 1
    I don't think this is the reason that others are suggesting TryGetValue. My solution is simplification, which I was not aware of. When I've found it out, I've pasted it here. And it seems that a lot of others didn't know about that also. Otherwise, they could also paste this answer and add that throws exception if key doesn't exist. Anyway, thanks for warning. – FrenkyB Aug 02 '18 at 10:31
  • 1
    For some reason I always forget this with Dictionaries... Like it doesn't seem like it should be this straightforward. – Ortund Jan 16 '21 at 12:46
  • Still a good solution when you know that values will always exiist. If not, it would still recommend the answers that suggest using TryGetValue(). – Koenman Mar 17 '21 at 12:27
38

That is not how the TryGetValue works. It returns true or false based on whether the key is found or not, and sets its out parameter to the corresponding value if the key is there.

If you want to check if the key is there or not and do something when it's missing, you need something like this:

bool hasValue = Data_Array.TryGetValue("XML_File", out value);
if (hasValue) {
    xmlfile = value;
} else {
    // do something when the value is not there
}
Sergey Kalinichenko
  • 697,062
  • 78
  • 1,055
  • 1,465
  • I have no use for hasValue : if (Data_Array.TryGetValue("XML_File", out value)) { xmlfile = value; } else { // do something when the value is not there } – The incredible Jan Mar 01 '22 at 10:13
28
Dictionary<String, String> d = new Dictionary<String, String>();
d.Add("1", "Mahadev");
d.Add("2", "Mahesh");
Console.WriteLine(d["1"]); // It will print Value of key '1'
Peter Mortensen
  • 30,030
  • 21
  • 100
  • 124
Mahadev Mane
  • 730
  • 7
  • 11
  • An explanation would be in order. E.g., what is the idea/gist? Please respond by [editing (changing) your answer](https://stackoverflow.com/posts/46582244/edit), not here in comments (***without*** "Edit:", "Update:", or similar - the answer should appear as if it was written today). – Peter Mortensen Nov 08 '21 at 04:16
9
static void XML_Array(Dictionary<string, string> Data_Array)
{
    String value;
    if(Data_Array.TryGetValue("XML_File", out value))
    {
        // ... Do something here with value ...
    }
}
Peter Mortensen
  • 30,030
  • 21
  • 100
  • 124
aqwert
  • 10,178
  • 2
  • 39
  • 58
5
static String findFirstKeyByValue(Dictionary<string, string> Data_Array, String value)
{
    if (Data_Array.ContainsValue(value))
    {
        foreach (String key in Data_Array.Keys)
        {
            if (Data_Array[key].Equals(value))
                return key;
        }
    }
    return null;
}
Jacek Lisiński
  • 113
  • 1
  • 6
  • How does that answer the question? *"How can I get the dictionary value by a key"* An explanation would be in order. E.g., what is the idea/gist? Please respond by [editing (changing) your answer](https://stackoverflow.com/posts/21003143/edit), not here in comments (***without*** "Edit:", "Update:", or similar - the answer should appear as if it was written today). – Peter Mortensen Nov 08 '21 at 04:09
  • Is this the answer to [a different question](https://stackoverflow.com/questions/2444033/get-dictionary-key-by-value)? – Peter Mortensen Nov 08 '21 at 04:10
3
private void button2_Click(object sender, EventArgs e)
{
    Dictionary<string, string> Data_Array = new Dictionary<string, string>();
    Data_Array.Add("XML_File", "Settings.xml");

    XML_Array(Data_Array);
}

static void XML_Array(Dictionary<string, string> Data_Array)
{
    String xmlfile = Data_Array["XML_File"];
}
Peter Mortensen
  • 30,030
  • 21
  • 100
  • 124
Suman Banerjee
  • 1,775
  • 4
  • 23
  • 39
  • An explanation would be in order. E.g., what is the idea/gist? What was changed? What was the fix? Please respond by [editing (changing) your answer](https://stackoverflow.com/posts/21310319/edit), not here in comments (***without*** "Edit:", "Update:", or similar - the answer should appear as if it was written today). – Peter Mortensen Nov 08 '21 at 04:12
3

Here is an example which I use in my source code. I am getting key and value from Dictionary from element 0 to number of elements in my Dictionary. Then I fill my string[] array which I send as a parameter after in my function which accept only params string[]

Dictionary<string, decimal> listKomPop = addElements();
int xpopCount = listKomPop.Count;
if (xpopCount > 0)
{
    string[] xpostoci = new string[xpopCount];
    for (int i = 0; i < xpopCount; i++)
    {
        /* here you have key and value element */
        string key = listKomPop.Keys.ElementAt(i);
        decimal value = listKomPop[key];

        xpostoci[i] = value.ToString();
    }
...

This solution works with SortedDictionary also.

Pang
  • 9,073
  • 146
  • 84
  • 117
Shixx
  • 51
  • 7
3
Dictionary<int,string> dict = new Dictionary<int,string>{
  {1,"item1"},
  {2,"item2"},
  {3,"item3"},
}

int key = 2 // for example
string result = dict.ContainsKey(key) ? dict[key] : null;
Andy Chang
  • 41
  • 3
  • 1
    This would search for the key twice in the dictionary. Why not use the out parameter of TryGetValue instead of searching a second time? Even with your code: Why even use TryGetValue instead of ContainsKey if you want to go that route? – BDL Apr 22 '21 at 08:20
2

I use a similar method to dasblinkenlight's in a function to return a single key value from a Cookie containing a JSON array loaded into a Dictionary as follows:

    /// <summary>
    /// Gets a single key Value from a Json filled cookie with 'cookiename','key' 
    /// </summary>
    public static string GetSpecialCookieKeyVal(string _CookieName, string _key)
    {
        //CALL COOKIE VALUES INTO DICTIONARY
        Dictionary<string, string> dictCookie =
        JsonConvert.DeserializeObject<Dictionary<string, string>>
         (MyCookinator.Get(_CookieName));

        string value;
        if (dictCookie.TryGetValue( _key, out value))
        {
            return value;
        }
        else
        {
            return "0";
        }

    }

Where "MyCookinator.Get()" is another simple Cookie function getting an http cookie overall value.

Martin Sansone - MiOEE
  • 4,123
  • 1
  • 27
  • 29
-2
if (Data_Array["XML_File"] != "") String xmlfile = Data_Array["XML_File"];
  • You have got some [explaining](https://stackoverflow.com/posts/54096267/edit) to do. (But ***without*** "Edit:", "Update:", or similar - the answer should appear as if it was written today). – Peter Mortensen Nov 08 '21 at 04:33