我有一个字典定义如下:
Dictionary<int, Dictionary<string, object>> dict = new Dictionary<..>();
用于添加数据的示例代码:
dict.Add (X, new Dictionary<string, object> ());
dict [X].Add ("Car", CarObject);
dict [X].Add ("Seller", SellerObject);
dict [X].Add ("Key3", Z);
我想在内部字典中搜索它是否包含一个包含以下内容的对象
关键“汽车”的CarObject.Name = (wildcard)X1(wildcard)
,但我似乎无法掌握如何进入内部字典,然后使用LINQ进入对象以搜索值。
答案 0 :(得分:1)
这将返回所有匹配的KeyValuePair<string, object>
。
var query = dict.SelectMany(d => d.Value)
.Where(i => i.Key == "Key1"
&& (
i.Value is CarObject
? ((CarObject)i.Value).Name.Contains("X1")
: false
));
答案 1 :(得分:0)
尝试以下方法:
var results = dict[X].Where(x => (x.Value is CarObject) && ((CarObject)x.Value).Name.Contains("X1"));
如果您只想获取值而不是字典,并打印值,则可以执行以下操作:
int X = 0, Z = 1;
dict[X].Add("Key1", CarObject);
dict[X].Add("Key2", SellerObject);
dict[X].Add("Key3", Z);
var results = dict[X].Where(x => (x.Value is CarObject) && ((CarObject)x.Value).Name.Contains("X1")).Select(x => x.Value);
foreach (var str in results)
Console.WriteLine(str);
答案 2 :(得分:0)
您可以尝试以下内容:
dict[X].Where(x => x.Value is CarObject && ((CarObject)x.Value).Name.Contains("X1"));
或者:
dict[X].Values.OfType<CarObject>().Any(x => x.Name.Contains("X1"))