[英]Compare 2 List<Dictionary<string,object>> in c#
我有2本字典清单
List<Dictionary<string,object>> master
List<Dictionary<string,object>> sub
我的两个词典都有相同的键名。
EX: The first list Master contains
Master.Add(new Dictionary<string, string>(){
{"key1","SAME1"}
{"key2", "value1"},
{"key3","value2"}
});
Master.Add(new Dictionary<string, string>(){
{"key1","SAME2"}
{"key2", "value3"},
{"key3","value5"}
});
Master.Add(new Dictionary<string, string>(){
{"key1","SAME77"}
{"key2", "value55"},
{"key3","value44"}
});
The second list sub contains similar kind of key,value pairing :
sub.Add(new Dictionary<string, string>(){
{"key1","SAME1"}
{"key2", "value7"},
{"key3","value9"}
});
Master.Add(new Dictionary<string, string>(){
{"key1","SAME2"}
{"key2", "value3"},
{"key3","value4"}
});
我可以使用LinQ中的一种方法(或任何其他更简便的方法)来比较字典的2个列表并获得输出Dictionary。 例
方案1:如您所见,我可以使用第一个字典列表中的一个键(Key1,因为它的所有值都相同),以查看该值是否存在于第二个词典中,如果不存在,我希望缺少它新列表中的字典>。
Output Ex: NewList.Add(new Dictionary<string, string>(){
{"key1","SAME77"} // since SAME77 isn't present in sub dictionary
{"key2", "value55"},
{"key3","value44"}
}
方案2:如果假设词典子列表中的一个词典包含key1的相同值,则我想检查同一词典的其他值,以及这些键的任何值是否已更改,如果它们具有,我想要一个具有原始列表的新列表。
ex输出:
NewList.Add(new Dictionary<string, string>(){
{"key1","SAME2"}
{"key2", "value3"},
{"key3","value5"} // since the master dictionary has value5 and the sublist dictionary has value 4
}
方案1尝试:
var result = Master.SelectMany(m=>m).Where(e=>sub.SelectMany(a=>a)
.Any(p => e.Key == p.Key && p.Value!=null && e.Value!=(p.Value)));
但是,这不会返回正确的结果,并且输出为IEnumerable。 我可以通过linq本身获得所需的输出吗?
感谢任何帮助
请注意,您的数据结构并不理想。 由于您将第一个键的第一个值视为“键”,因此您可能需要考虑重新创建结构,以将“ SAME1”(和类似值)用作键。
也就是说,您仍然可以在“单行” LINQ语句中完成两个查询。
var masterOnly = Master.Where(m =>
!sub.Select(s => s.First().Value).Contains(m.First().Value)
).ToList();
在仅主机的情况下,我们使用Where子句允许我们首先构建子-> first->值的集合,然后针对该集合检查循环中的每个master-> first->值。 如果该值不存在,则返回该值。
var hasChanged = Master.Where(m =>
sub.FirstOrDefault(s =>
s.First().Value == m.First().Value)?.SequenceEqual(m) == false)
.ToList();
在这种情况下,我们可以利用C#6的null传播运算符来避免使用.ForEach()
在循环中构建匹配项,因为如果该值为null,则将忽略SequenceEquals检查。
如果我们有一个匹配项,我们想将其序列与我们的主集合进行显式比较,如果任何条目不匹配,我们将其返回。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.