Consulta LINQ para retornar um Dicionário <string, string>


218

Eu tenho uma coleção de MyClass que gostaria de consultar usando LINQ para obter valores distintos e retornar um Dictionary <string, string> como resultado, mas não consigo descobrir como fazê-lo de maneira mais simples do que eu. estou fazendo abaixo. Qual seria um código mais limpo que eu possa usar para obter o Dictionary <string, string> como resultado?

var desiredResults = new Dictionary<string, string>(StringComparer.OrdinalIgnoreCase);

var queryResults = (from MyClass mc in myClassCollection
                    orderby bp.SomePropToSortOn
                    select new KeyValuePair<string, string>(mc.KeyProp, mc.ValueProp)).Distinct();

foreach (var item in queryResults)
{
    desiredResults.Add(item.Key.ToString(), item.Value.ToString());
}

6
O que você quer fazer com chaves duplicadas? Basta pegar o primeiro e ignorar os subsequentes? Esteja ciente de que os dicionários não são ordenados, assim que sua ordenação na consulta não terá nenhum efeito ...
Jon Skeet

1
Talvez o que você está procurando seja a implementação SortedDictionary do IDictionary. Caso contrário, a classificação sobre um dicionário é inútil.
Fede

Respostas:


366

Use o ToDictionarymétodo diretamente.

var result = 
  // as Jon Skeet pointed out, OrderBy is useless here, I just leave it 
  // show how to use OrderBy in a LINQ query
  myClassCollection.OrderBy(mc => mc.SomePropToSortOn)
                   .ToDictionary(mc => mc.KeyProp.ToString(), 
                                 mc => mc.ValueProp.ToString(), 
                                 StringComparer.OrdinalIgnoreCase);

1
Mehrdad, obrigado pelo ponteiro sobre isso. Essa era a direção em que eu estava indo, mas devia estar negligenciando a sobrecarga correta do ToDictionary.
9119 Scott Ivey

18

Veja os métodos ToLookupe / ou ToDictionaryextensão.

Ao utilizar nosso site, você reconhece que leu e compreendeu nossa Política de Cookies e nossa Política de Privacidade.
Licensed under cc by-sa 3.0 with attribution required.