LINQ - 按 GroupBy 分组并投影到新类型?

3
我有一个项目列表,即 List<SearchFilter>,这是 SearchFilter 对象:
public class SearchFilter
{
    public int ItemID { get { return ValueInt("ItemID"); } }
    public string ItemName { get { return ValueString("ItemName"); } }
    public string Type { get { return ValueString("Type"); } }
}

如何按Type分组,并将分组后的项投影到一个新的GroupedFilter列表中,即:

public class Filter
{
    public int ItemID { get; set; }
    public string ItemName { get; set; }
}

public class GroupedFilter
{
    public int Type { get; set; }
    public List<Filter> Filters { get; set; }
}

谢谢。
2个回答

5
var result = items.GroupBy(
    sf => sf.Type,
    sf => new Filter() { ItemID = sf.ItemID, ItemName = sf.ItemName },
    (t, f) => new GroupedFilter() { Type = t, Filters = new List<Filter>(f) });

但是你需要确保你的GroupedFilter.Type属性是一个字符串,以匹配你的SearchFilter.Type属性。


0

使用Linq查询语法会更长、更复杂,但仅供参考:

var grpFilters = (from itm in list group itm by itm.Type into grp select
                    new GroupedFilter
                    {
                        Type = grp.Key,
                        Filters = grp.Select(g => new Filter 
                                                  {
                                                      ItemID = g.ItemID,
                                                      ItemName = g.ItemName
                                                  }).ToList()
                    }).ToList();

有些人可能会觉得这样更易读,因为他们不知道GroupBy()的所有可能参数。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接