値を指定してキーを取得できません。これを達成するための最良の方法は何ですか?
var st1= new List<string> { "NY", "CT", "ME" };
var st2= new List<string> { "KY", "TN", "SC" };
var st3= new List<string> { "TX", "OK", "MO" };
var statesToEmailDictionary = new Dictionary<string, List<string>>();
statesToEmailDictionary.Add("[email protected]", st1);
statesToEmailDictionary.Add("[email protected]", st2);
statesToEmailDictionary.Add("[email protected]", st3);
var emailAdd = statesToEmailDictionary.FirstOrDefault(x => x.Value.Where(y => y.Contains(state))).Key;
FirstOrDefault
からの戻り値はKeyValuePair<string, List<string>>
になるため、キーを取得するには、Key
プロパティを使用します。このような:
var emailAdd = statesToEmailDictionary
.FirstOrDefault(x => x.Value.Contains(state))
.Key;
または、クエリ構文で同等のものを次に示します。
var emailAdd =
(from p in statesToEmailDictionary
where p.Value.Contains(state)
select p.Key)
.FirstOrDefault();
このスレッドの全員が言及しなかったことは、FirstOrDefault
メソッドは Linq を介してのみ利用できることです。
using System;
using System.Collections.Generic;
// FirstOrDefault is part of the Linq API
using System.Linq;
namespace Foo {
class Program {
static void main (string [] args) {
var d = new Dictionary<string, string> () {
{ "one", "first" },
{ "two", "second" },
{ "three", "third" }
};
Console.WriteLine (d.FirstOrDefault (x => x.Value == "second").Key);
}
}
}
私はあなたが望むと思います:
var emailAdd = statesToEmailDictionary.FirstOrDefault(x => x.Value.Any(y => y.Contains(state))).Key;
var emailAdd = statesToEmailDictionary
.FirstOrDefault(x => x.Value != null && x.Value.Contains(state))
.Key;
ただし、パフォーマンスを求める場合は、辞書を逆にして<state, email>
の辞書を作成し、探していることを行うことをお勧めします。
// To handle when it's not in the results
string emailAdd2 = null;
foreach (var kvp in statesToEmailDictionary)
{
if (kvp.Value != null && kvp.Value.Contains(state))
{
emailAdd2 = kvp.Key;
break;
}
}
var emailAdd = statesToEmailDictionary.First(x=>x.Value.Contains(state)).Key;
それを行う単純なLinq
Dim mKP = (From mType As KeyValuePair(Of <Key type>, <Value type>) In <Dictionary>
Where mType.Value = <value seeked> Select mType).ToList
If mKP.Count > 0 then
Dim value as <value type> = mKP.First.Value
Dim key as <Key type> = mKP.First.Key
End if
もちろん、重複する値がある場合、これは複数のKeyValuePair
を返します