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 ...
有人可以协助吗?
,
您的密钥应该是同时包含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)
| 归档时间: |
|
| 查看次数: |
6091 次 |
| 最近记录: |