2013-03-01 264 views
0

我有3个列表cab类型。我需要比较listAlistB。如果Car-numberstatuslistBlistA中的相同,那么我必须在listBlistC' else add it to listA . I need to perform that same operation for all rows for listB`中加上那一行。我如何在两个列表上编写lambda来执行此操作?Lambda来比较两个列表

这是我到目前为止的代码:

public class cab 
{ 
    public string Name {get;set;} 
    public string Desc {get;set;} 
    public int Car_number {get;set;} 
    public bool status {get;set;} 

} 
cab c1 = new cab() { Name = "Zen",Desc = "äsdasdf",Car_number= "8832",status="false"}; 
cab c2 = new cab() { Name = "Ford",Desc = "sdfgedasdf",Car_number= "1132",status="true"}; 
cab c3 = new cab() { Name = "Swift",Desc = "sdsdf",Car_number= "732",status="true"}; 

List<cab> listA = new List<cab>(); 

listA.Add(c1); 
listA.Add(c2); 
listA.Add(c3); 


List<cab> listB = new List<cab>(); 
cab c4 = new cab() { Name = "Santro",Desc = "iisdasdf",Car_number= "8832",status="false"}; 
cab c5 = new cab() { Name = "Ritz",Desc = "esddf",Car_number= "132",status="true"}; 

listB.Add(c4); 
listB.Add(c5); 
List<cab> listC = new List<cab>(); 
+2

你有什么尝试?你有没有使用更传统的迭代方法?如果你只是学习LINQ,那么你至少应该从那里开始,即使你希望在某个时候有一个LINQ解决方案。 – Servy 2013-03-01 05:25:51

+0

将有助于至少获得正确的数据类型: 'Car_number =“8832”' – 2013-03-01 05:30:27

回答

2

任何具体原因需要拉姆达?

这会适合你吗?

foreach (var bItem in listB) 
{ 
    if (listA.Any(aItem => bItem.Car_number == aItem.Car_number || bItem.status == aItem.status)) 
     listC.Add(bItem); 
    else 
     listA.Add(bItem); 
} 
+0

非常感谢! – user1799214 2013-03-07 04:38:00

0
listB.ForEach(b => 
    { 
     if (listA.Any(a => a.Car_number == b.Car_number || a.status == b.status)) 
     { 
     listC.Add(b); 
     } 
     else 
     { 
     listA.Add(b); 
     } 
    } 
); 
0

如果你真的想要的lambda表达式,试试这个:

public static void ChoiseAndAdd(Cab cab,ref List<Cab> listA,ref List<Cab> listC) 
    { 
     if (listA.Any(e => e.Car_number == cab.Car_number) || listA.Any(e => e.status == cab.status)) 
     { 
      listC.Add(cab); 
      return; 
     } 
     listA.Add(user); 
    } 

和表达:

listB.ForEach(e => ChoiseAndAdd(e, ref listA, ref listC)); 
0
//Populate list C 
listC = listA.Where(a=> listB.Select(b=>b.Car_number).Contains(a.Car_number) && listB.Select(b => b.status).Contains(a.status)).ToList(); 
//Populate ListB using ListC 
listB.AddRange(listA.Where(a => ! listC.Select(c => c.Car_number).Contains(a.Car_number) && ! listC.Select(c => c.status).Contains(a.status)).ToList()); 

注:我偶然发现这里有类似的问题,并澄清我的怀疑使用您的代码。我知道这是一个古老的问题,答案已经提供(并被接受)。但我想我会为其他可能来这里寻找答案的人发布上述解决方案。