我在 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 应该是包含 Expiry
和 EndDate
的复合 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/