I apologize in advance if my question is not clear, I am just starting to learn Javascript and this my first post.I am trying to reformat a data set:
console.log(dataset)
display the following (I am displaying here a few records):
[{"name":"HPH","income":["1976","2434"]},
{"name":"HPH","income":["1977","1658"]},
{"name":"HPH","income":["1978","1712"]},
{"name":"SWO","income":["1976","9913"]},
{"name":"SWO","income":["1977","8852"]},
{"name":"SWO","income":["1978","7152"]}]
I would like to get the following:
[{"name":"HPH","income":[["1976","2434"],["1977","1658"],["1978","1712"]]},
{"name":"SWO","income":[["1976","9913"],["1977","8852"],["1978","7152"]]}]
Any help will be much appreciated.
Frank
Try something like this:
var data = [{"name":"HPH","income":["1976","2434"]},
{"name":"HPH","income":["1977","1658"]},
{"name":"HPH","income":["1978","1712"]},
{"name":"SWO","income":["1976","9913"]},
{"name":"SWO","income":["1977","8852"]},
{"name":"SWO","income":["1978","7152"]}];
var final = [],
found = false,
i, j;
for (i in data) {
for(j in final) {
if (final[j].name == data[i].name) {
found = true;
final[j].income.push(data[i].income);
break;
}
}
if (found) {
found = false;
continue;
}
var obj = {name: data[i].name, income: [data[i].income]};
final.push(obj);
}
console.log(final);
var a = [{"name":"HPH","income":["1976","2434"]},
{"name":"HPH","income":["1977","1658"]},
{"name":"HPH","income":["1978","1712"]},
{"name":"SWO","income":["1976","9913"]},
{"name":"SWO","income":["1977","8852"]},
{"name":"SWO","income":["1978","7152"]}],
b = {},
c = [];
for(var i = 0; i < a.length; i++) {
if(!b[a[i].name])b[a[i].name] = [];
for(var j = 0; j < a[i].income.length){
b[a[i].name].push(a[i].income[j]);
}
}
// Here you have an object like
// b = {HPH : ["1976","2434", "1978","1712"], SWO : ["1977","8852", "1977","8852","1978","7152"};
for(var k in b){
c.push({name : k, income : b[k]}
}
I invite you to read : Eloquent JS who's a very helpful reading and if you get the motivation ( MDN ( Arrays )) to be a pro!
Try also, just using filter
and reduce
:
var dataset = [{"name":"HPH","income":["1976","2434"]},{"name":"HPH","income":["1977","1658"]},{"name":"HPH","income":["1978","1712"]},{"name":"SWO","income":["1976","9913"]},{"name":"SWO","income":["1977","8852"]},{"name":"SWO","income":["1978","7152"]}]; var result = dataset.reduce(function(data, item){ var existitem = data.filter(function(i){ return i.name === item.name })[0] || {name: item.name, income: []}; !existitem.income.length && data.push(existitem); existitem.income.push(item.income); return data }, []) document.write(JSON.stringify(result))
The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.