0

我想BeerNames从一个不在第二个列表中的列表中获得一个列表。

var myList=(from f in Beers where ...
              select f.BeerNames).ToList

var storeList(from f in Store where...
                select f).ToList()

MyList 将有一些不在 StoreList 上的 BeerNames。我如何找到那些 BeerNames?我试过了.Except!Contains但我意识到我做错了什么,并且错过了一些关键的知识。谢谢

如果我改变

var storeList(from f in Store where...
                select f).ToList()

var storeList(from f in Store where...
                select f.BeerNames).ToList()

然后我可以使用除了List1.Except(List2). 我不确定是否有更好的方法。对不起,如果这不清楚......我正在尝试:)

4

2 回答 2

2
var list1 = new String[] {"ABC1","ABC2", "ABC3", "ABC4"} ;
var list2 = new String[] {"ABC3","ABC4", "ABC5", "ABC6"} ;
var list3 = list1.Except(list2); // list3 holds ABC1, ABC2

除了工作正常。

我怀疑问题出在从 linq 查询返回的项目中。似乎首先是 f.BeerNames,而 StoreList 中的 f 没有指向相同的数据类型。

对于异种类型

var list1 = from s in new String[] {"ABC1","ABC2", "ABC3", "ABC4"} select new {BeerName=s,Id = Guid.NewGuid().ToString()}  ;
var list2 = new String[] {"ABC3","ABC4", "ABC5", "ABC6"} ;
var intermediateList = list1.Select(i=>i.BeerName).Except(list2);
var list3 = from l1 in list1
        join l2 in intermediateList on l1.BeerName equals l2
        select l1;


list1.Dump(); // run in linqPad
intermediateList.Dump();// run in linqPad
list3.Dump();// run in linqPad

list3 返回以下

啤酒名称 ID

ABC1 569ace9a-66c4-46aa-bbf5-50d586a2886f

ABC2 af456094-9692-4771-b489-8b3cca8aa938

使用LinqPad运行上述程序,或删除 .Dump() 以在 VS 中执行。

于 2012-05-08T14:51:20.290 回答
1

除了应该使用字符串类型

var myList = MyFrig.Select(f => f.BeerNames).Except(Store).ToList();
于 2012-05-08T14:50:40.977 回答