'Compare Dictionary Key of type string to another string in C#

I'm actually trying to check if a string is equal to any of the key's in my Dictionary object.

Here is what I have done so far:

using (var oStreamReader = new StreamReader(path))
{
    Dictionary<String, String> typeNames = new Dictionary<string, string>();
    typeNames.Add("Kind","nvarchar(1000)");
    typeNames.Add("Name","nvarchar(1000)");
    DataTable oDataTable = new DataTable();

    var headLine = oStreamReader.ReadLine().Trim().Replace("\"", ""); 
    var columnNames = headLine.Split(new[] { ';' });

    String[] oStreamDataValues;

    /*
    *create DataTable header with specific datatypes and names
    */

    int countCol = 0;

    foreach (string readColumn in columnNames)
    {


        if ((readColumn.ToString().Replace("\"", "").CompareTo(typeNames) == true))
        {
            // this comparison doesn't work
        }
    }
}


Solution 1:[1]

I have solved this (by inspiration of Paul Houlston and Thomas Lielacher)

string headLine = oStreamReader.ReadLine().Trim().Replace("\"", ""); 
string columnNames = headLine.Split(new[] { ';' });

foreach (string readColumn in columnNames)
{
    if (typeNames.Keys.Contains(readColumn, StringComparer.CurrentCultureIgnoreCase) == true)
    {
       DataColumn oDataColumn = new DataColumn(readColumn,typeof(System.String));
       oDataTable.Columns.Add(oDataColumn);
    }
}

Solution 2:[2]

I am not quite sure what exactly you are trying to achieve. If you have a C# dictonary you can use linq to check for values that match the required value, e.g.

string valueToCompare = "Value to match";
Dictionary<string, string> dict = new Dictionary<string, string> 
                                  {
                                    {"Key 1", "A value"}, 
                                    {"Key 2", "Another value"}
                                  };
bool found= dict.Values
                .Any(value 
                     => 
                     value.Equals(valueToCompare,
                                  StringComparison.CurrentCultureIgnoreCase)
                    );

Solution 3:[3]

Since you want check if exist an entry in your Dictionary that as the same key of one of the values in your columnNames object I suggest you to use ContainsKey method

Solution 4:[4]

Dictionary<string, string> d = new Dictionary<string, string>();
            string keyvalue;
            if (d.ContainsKey("value to find"))
            {
                if (d.TryGetValue("value to find", out keyvalue))
                {
                    //// here keyvalue variable has the value 
                }
                else
                {
                    ///value is null or throws exception
                }
            }
            else
            {
                    ////key no exists
            }

Sources

This article follows the attribution requirements of Stack Overflow and is licensed under CC BY-SA 3.0.

Source: Stack Overflow

Solution Source
Solution 1 Matthias Müller
Solution 2 Ehsan Sajjad
Solution 3 Tinwor
Solution 4 Dreamweaver