javascript linq.js groupby

标签 javascript group-by linq.js

我在 Javascript 函数中有以下 JSON 数据(此处进行了简化):

var data = [
  { Expiry: "2013-01-02T00:00:00", EndDate: "2013-01-16T00:00:00", Category: 10, Amount: 14.53 },
  { Expiry: "2013-01-02T00:00:00", EndDate: "2013-01-16T00:00:00", Category: 25, Amount: 14.86 },
  { Expiry: "2013-02-06T00:00:00", EndDate: "2013-02-20T00:00:00", Category: 10, Amount: 14.43 },
  { Expiry: "2013-02-06T00:00:00", EndDate: "2013-02-20T00:00:00", Category: 25, Amount: 14.76 }
];

注意:对于任何特定的到期值,EndDate 值始终相同。

现在,理想情况下,我希望在末尾添加以下 JSON(按到期日期分组,并注意属性名称中类别值的使用):

[
   {
     Expiry: 2013/1/2,     (note: not fussed about the date format)
     EndDate: 2013/1/16,
     Category10: 14.53,
     Category25: 14.86
   },
   {
     Expiry: 2013/2/6,
     EndDate: 2013/2/20,     
     Category10: 14.43,
     Category25: 14.76
   },
]

但不确定我是否会一次性得到所有这些,因此可以在每个日期对下确定一系列类别和金额,然后我可以处理它们以某种方式获得上述内容:

[
   {
     Expiry: 2013/1/2,    
     EndDate: 2013/1/16,
     Categories: [ { 10, 25 } ],
     Amounts: [ { 14.53, 14.86 } ]
   },
   {
     Expiry: 2013/2/6,
     EndDate: 2013/2/20,
     Categories: [ { 10, 25 } ],
     Amounts: [ { 14.43, 14.76 } ]
   },
]

我尝试使用 linq.js 库中的 groupby 函数来获取必要的 JSON,但无法获取我需要的内容。

具有以下内容:

var result = linq.groupBy("$.Expiry", "", "k,e => { Expiry: k, Categories: e.select('$.Category').toArray(), Amounts: e.select('$.Amount').toArray()}").toArray();

我得到:

[
   {
     Expiry: 2013/1/2,    
     Categories: [ { 10, 25 } ],
     Amounts: [ { 14.53, 14.86 } ]
   },
   {
     Expiry: 2013/2/6,
     Categories: [ { 10, 25 } ],
     Amounts: [ { 14.43, 14.76 } ]
   },
]

但我无法弄清楚如何获取 EndDate...

有人可以帮忙吗?

塔,

最佳答案

您的 key 应该是包含 ExpiryEndDate 的复合 key 。然后您可以将其包含在结果中。

我不建议尝试获得理想的结果,创建这样的结果不符合 LINQ 的初衷。相反,您应该收集您正在查询的项目。

var query = Enumerable.From(data)
    .GroupBy(
        "{ Expiry: $.Expiry, EndDate: $.EndDate }",
        null,
        "{ Expiry: $.Expiry, EndDate: $.EndDate, Categories: $$.Select('$.Category').ToArray(), Amounts: $$.Select('$.Amount').ToArray() }",
        "$.Expiry + '-' + $.EndDate" // compare selector needed
    )
    .ToArray();

但是仍然有可能获得理想的结果,但我再次建议不要使用这种方法。

var query = Enumerable.From(data)
    .GroupBy(
        "{ Expiry: $.Expiry, EndDate: $.EndDate }",
        null,
        function (key, g) {
            return g.Aggregate({
                Expiry: key.Expiry,
                EndDate: key.EndDate
            }, function (result, item) {
                result['Category' + item.Category] = item.Amount;
                return result;
            });
        },
        "$.Expiry + '-' + $.EndDate"
    )
    .ToArray();

关于javascript linq.js groupby,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15642333/

相关文章:

JavaScript:将变量设为默认值?

javascript - 如何使 JavaScript Math.random 重复?

javascript - 当我单击“打开”按钮时,页面中应出现一个文本框

mysql - 查询日期范围内所需的汽车

javascript - Linq.js : Group By two properties (fields)

javascript - 使用 linq.js 从多个对象创建 JSON 对象数组

javascript - Linq.js 对 Json 数据的功能不起作用

javascript - 如何同步两个不同页面上的按钮?

python - 用 Pandas 标记列中的重复值

具有多个 group by 的 Mongodb 聚合