3

我是Linq的新手。我想知道这是否是最好的方法还是有其他方法可以做到这一点。

我有一个要求,我从 Web 服务中收到一个项目列表:

class Item {

  string ItemName { get; set;} 
  string GroupName { get; set; }
}

我收到以下数据:

ItemName: Item1; GroupName: A
ItemName: Item2; GroupName: B
ItemName: Item3; GroupName: B
ItemName: Item4; GroupName: A
ItemName: Item5; GroupName: A

现在我想获取列表中的所有唯一组,并将所有项目与该组相关联。所以我做了一个类:

class Group {
   string GroupName { get; set; }
   List<string> Items { get; set; }
}

这样就有一个组,所有关联的项目都将在列表下。

我做了两个 LINQ 语句:

var uniqueGroups = (from g in webservice
        where g.Group != null
        select g.GroupName).Distinct();

然后我遍历它

foreach (var gn in uniqueGroups)
{
   var itemsAssociated = (from item in webservice 
                          where item.GroupName = gn.ToString()
                          select new {
                               });
}

然后我得到了这些物品,并将它们保存到我的对象中。

这是执行此操作的最佳方法,还是有任何 LINQ 语句可以一次性完成所有这些操作?

谢谢。

4

4 回答 4

6

听起来你想要GroupBy

var itemsByGroup = items.GroupBy(i => i.GroupName);

foreach (var group in itemsByGroup)
{
    var groupName = group.Key;
    var itemsForThisGroup = group;

    foreach (var item in itemsForThisGroup)
    {
        Console.Out.WriteLine(item.ItemName);
    }
}
于 2012-06-29T10:47:17.443 回答
4

你可以试试这个:

//List<Item> webservice = list with items from your webservice
var result = (from i in items
              group i by i.GroupName into groups
              select new Group()
              {
                  GroupName = groups.Key,
                  Items = groups.Select(g => g.ItemName).ToList()
              }).ToList();
于 2012-06-29T10:46:03.470 回答
1

这可以使用匿名类型一次性完成,并且Enumerable.GroupBy

var groupItems =
    webservice.Where(i => i.GroupName != null)
              .GroupBy(i => i.GroupName)
              .Select(grp => new { Group = grp.Key, Items = grp.ToList() });
foreach (var groupItem in groupItems)
    Console.WriteLine("Groupname: {0} Items: {1}"
        , groupItem.Group
        , string.Join(",", groupItem.Items.Select(i => i.ItemName)));

Distinct 是无用的,因为GroupBy总是会使组不同,这就是组的性质。

这是运行代码:http: //ideone.com/R3jjZ

于 2012-06-29T10:50:59.310 回答
1

我会使用:

 webservice.ToLookup(k => k.GroupName);

这将消除对额外课程的需要。

希望这可以帮助!

于 2012-06-29T10:52:58.390 回答