javascript linq.js groupby

tre*_*003 0 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 }
];
Run Code Online (Sandbox Code Playgroud)

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

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

[
   {
     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
   },
]
Run Code Online (Sandbox Code Playgroud)

但是不确定我是否会一劳永逸,因此可以解决每个日期对下的类别和金额数组的问题,然后我就可以处理这些问题以某种方式得到上述结果:

[
   {
     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 } ]
   },
]
Run Code Online (Sandbox Code Playgroud)

我正在尝试使用linq.js库中的groupby函数来获取必要的JSON,但无法获得所需的信息。

具有以下内容:

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

我得到:

[
   {
     Expiry: 2013/1/2,    
     Categories: [ { 10, 25 } ],
     Amounts: [ { 14.53, 14.86 } ]
   },
   {
     Expiry: 2013/2/6,
     Categories: [ { 10, 25 } ],
     Amounts: [ { 14.43, 14.76 } ]
   },
]
Run Code Online (Sandbox Code Playgroud)

但是我无法锻炼如何获得EndDate ...

有人可以协助吗?

Jef*_*ado 5

您的密钥应该是同时包含Expiry和的复合密钥EndDate。然后,您可以将其包括在结果中。

我不建议您尝试获得理想的结果,创建这样的结果不符合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();
Run Code Online (Sandbox Code Playgroud)

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

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();
Run Code Online (Sandbox Code Playgroud)