首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >对多个字段使用group by的linq.js

对多个字段使用group by的linq.js
EN

Stack Overflow用户
提问于 2015-01-28 07:56:04
回答 1查看 1.6K关注 0票数 2

我目前有一个对象数组,比如

代码语言:javascript
复制
[{Test: "123", Two: "234"}, {Test: "123", Two: "234"}, {Test: "123", Two: "222"}]

使用linq.js,我如何运行group by并返回一个列表,该列表返回重复(测试,两个)值的计数。我希望我的输出是这样的:

代码语言:javascript
复制
[{Key: {Test: "123", Two: "234"}, Value:2}, {Key: {Test: "123", Two: "222"}, Value:1}  ]

我认为Linq.js中的GroupBy方法可能会有所帮助,但是我不确定如何使用它。

EN

回答 1

Stack Overflow用户

发布于 2015-01-29 12:17:43

您需要使用包含比较选择器的GroupBy()重载。您的键是对象,但您需要提供一种比较它们的方法。将项目映射到可以比较的东西(例如,键的字符串)。

代码语言:javascript
复制
var data = [
    { Test: "123", Two: "234" },
    { Test: "123", Two: "234" },
    { Test: "123", Two: "222" }
];
var query = Enumerable.From(data)
    // GroupBy (keySelector, elementSelector, resultSelector, compareSelector)
    .GroupBy(
        null, // (identity)
        null, // (identity)
        "{ Key: $, Value: $$.Count() }",
        "'' + $.Test + '-' + $.Two"
    )
    .ToArray();
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28182265

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档