Linq明显算数

时间:2012-08-27 22:46:45

标签: c# linq

我有一些数据返回如下:

Model { Guid Id }

我的总项目为int totalCount

我正在尝试从作为类别1返回的数据中获取不同的计数, 并将总项目减去第1类的计数为第2类。

我有以下linq来获取类别1的非重复计数,但是如何将类别2的计数添加到IEnumerable中?

var result = data.
    GroupBy(x => x.Id).
    Select(x => new { Category = "1", Value = x.Select(v => v.Id).Distinct().Count() }).
    GroupBy(x => x.Category).
    Select(x => new Item { Category = x.Key, Value = x.Sum(y => y.Value) });

和Item Class有2个成员:Category的字符串和Value的小数。

谢谢!


编辑: 所以我有以下数据IEnumerable<Model> data,它包含以下数据:

{ Id: 1 }
{ Id: 2 }
{ Id: 2 }
{ Id: 1 }
{ Id: 3 }
{ Id: 4 }

和totalCount = 10。

我想从数据中获取Id的独特计数,在这种情况下为4,作为类别1,而totalCount - 不同的项目为类别2.因此,对于结果,我将得到IEnumerable Item得到以下内容:

{ Category: "1", Value: 4 }, { Category: "2", Value: 6 }

现在我的linq语句只返回{ Category: "1", Value: 4 },我不知道下一步该做什么。

3 个答案:

答案 0 :(得分:9)

你的问题不是很清楚,但我认为这就是你想要的:

int totalCount = data.Count();
int distinctCount = data.Select(x => x.Id).Distinct().Count();
List<Item> result = new List<Item>
{
    new Item() { Category = "1", Value = distinctCount },
    new Item() { Category = "2", Value = totalCount - distinctCount },
};

答案 1 :(得分:0)

您在一天结束时是否需要两个物品,或者它只是一次返​​回的一部分?你可以这么做:

var result = data.
    GroupBy(x => x.Id).
    Select(x => new { 
       DistinctCount = x.Select(v => v.Id).Distinct().Count(),
       TotalCount = data.Count()
    });

这类或类似的东西可能有用。

答案 2 :(得分:0)

我使用数据结构来面对这种情况。

Dictionary< string, List< YOUR_TYPE >> dictionary = new Dictionary<string, List< YOUR_TYPE >> ();

我们可以从源代码获得不同的密钥。

var keys = YOUR_DATA_SOURCE.Select(item => item.YOUR_KEY_NAME ).Distinct();

就像SQL:“从YOUR_DATA_SOURCE选择DISTINCT YOUR_KEY_NAME”。

foreach (var key in keys) {
    var list = new List< YOUR_TYPE > ();
    list.AddRange (dataSource.Where (x => x.YOUR_Filter_Property == YOUR_KEY_NAME ).ToList ());

    dictionary.Add (key, list);
}

然后我们可以使用Dictionary的默认功能,如“ContainKey”,“Keys”来帮助我们。