- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个如下所示的列表:
var products = new List<Product>
{
new Product { Id = 1, Category = "Electronics", Value = 15.0 },
new Product { Id = 2, Category = "Groceries", Value = 40.0 },
new Product { Id = 3, Category = "Garden", Value = 210.3 },
new Product { Id = 4, Category = "Pets", Value = 2.1 },
new Product { Id = 5, Category = "Electronics", Value = 19.95 },
new Product { Id = 6, Category = "Pets", Value = 5.50 },
new Product { Id = 7, Category = "Electronics", Value = 250.0 },
};
我想按类别分组并获取属于该类别的“值”的总和..示例:电子产品:284.95
虽然我可以通过其他方式做到这一点,但我想学习 Look-Up 的用法。
是否有可能在查找中获得这 2 个值(类别和值)?如果是,我该怎么做?
最佳答案
当您从 Lookup 中按键检索时,它的行为就像一个分组,因此您可以这样做:
var productLookup = products.ToLookup(p => p.Category);
var electronicsTotalValue = productLookup["Electronics"].Sum(p => p.Value);
var petsTotalValue = productLookup["Pets"].Sum(p => p.Value);
//etc
var totalValue = products.Sum(p => p.Value);
// I wouldn't use the Lookup here, the line above makes more sense and would execute faster
var alsoTotalValue = productLookup.Sum(grp => grp.Sum(p => p.Value));
关于c# - 使用 List.ToLookup(),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16075092/
鉴于此: [ ("A","A122"); ("A","A123"); ("B","B122"); ("B","B123"); ("C","C122"); ] 是
我正在研究将可枚举序列转换为字典类型数据结构的 Enumerable.ToLookup API。可以在此处找到更多详细信息: https://msdn.microsoft.com/en-us/libr
LINQ 提供的 .ToLookup 函数有没有办法要求多个键? 我承认这乍一看似乎不直观,我预计没有实际的方法可以做到这一点,但我希望有人知道方法。 我基本上希望能够通过两个值进行查找,例如 str
考虑到下面的 C# 控制台应用程序代码,使用 我应该如何修改它以替换行: foreach (Product product in productsByCategory[category]) 通过代码行
我有一个如下所示的列表: var products = new List { new Product { Id = 1, Category = "Electronics", Value = 1
var tmpProjection = myCollection.ToLookup(t => t.SomeBoolValue); var listOneFinal = tmpProjection[tr
我正在尝试转 IEnumerable>进入 ILookup使用以下代码: var list = new List>() { new KeyValuePair("London", null),
我有一个巨大的点数据类型列表和一个相等大小的双列表。大小可能在 1000000 左右。两个列表都来自不同的类。 List XYPair; E.g. { (10,10),(10,10).......(
.ToLookup 返回 ILookup . ILookup还实现了接口(interface) IEnumerable> . .GroupBy 返回 IEnumerable> . ILookup 具有
LINQ ToDictionary 和 ToLookup 有什么区别?他们似乎在做同样的事情。 最佳答案 字典是一个 1:1 映射(每个键映射到一个值),并且字典是事后可变(可编辑)的。 查找是一个
我有一个每小时运行一次的 PowerShell 脚本,它基本上通过滴灌过程更新产品信息。该脚本在开发环境中失败,但在生产和质量中继续工作。故障点在使用 LINQ 的线路上。这是脚本: $product
我有以下产品列表 public sealed class Product { public int Id { get; set; } public string Category {
我是一名优秀的程序员,十分优秀!