我有一个列表,其中包含类别和产品作为属性,我希望将与所有类别相关的产品分开到不同的列表中。
目前我有这个
Products products = new Products();
products.productList.Add(new Products("Fruit", "Apples"));
products.productList.Add(new Products("Fruit", "Oranges"));
products.productList.Add(new Products("Fruit", "Bananas"));
products.productList.Add(new Products("Fruit", "Grapes"));
products.productList.Add(new Products("Vegetables", "Tomatoes"));
products.productList.Add(new Products("Vegetables", "Lettuce"));
products.productList.Add(new Products("Vegetables", "Onions"));
products.productList.Add(new Products("Dairy", "Milk"));
products.productList.Add(new Products("Dairy", "Yogurth"));
products.productList.Add(new Products("Dairy", "Eggs"));
List<IEnumerable<string>> distinctCats = products.productList.GroupBy(s => s.Category).Select(s => s.Select(v => v.Product)).ToList();
但我似乎无法从distinctCats中获取值。我希望得到类似普通List productList的实际值。
感谢您的帮助和时间
答案 0 :(得分:10)
如果要按类别将列表划分为子列表:
var categoryLists = products.GroupBy(p => p.Category)
.Select(g => g.ToList());
现在,categoryLists
是IEnumerable<List<Product>>
。
要迭代这个,你可以说:
foreach(var categoryList in categoryLists) {
foreach(var product in categoryList) {
// do something with product
}
}
答案 1 :(得分:1)
不确定我理解你想要什么,但似乎你需要这样的东西:
var products=new List<Product>{};
var productsInCategories=products.ToLookup(p=>p.Category);
现在每个产品Categories [i]都包含一个“subList”(实际上是IEnumerable)。