我在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(按到期日期分组,并注意在属性名称中使用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
},
]
但不确定我是否会一次性完成这一切,所以可以在每个日期对之下解决一系列类别和金额,然后我可以处理以获得上述方式:
[
{
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 ...
有人可以帮忙吗?
的Ta,
答案 0 :(得分: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();
然而,仍然可以获得理想的结果,但我再次建议不要使用这种方法。
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();