Получить количество объектов массива, принадлежащих частичному идентификатору в JavaScript / Node js - PullRequest
3 голосов
/ 30 мая 2019

У меня есть массив таких массивов:

var array = [ 
    [ '2','Yes'],
    [ '2','Yes'],
    [ '2','Yes'],
    [ '3','Yes'],
    [ '3','Yes'],
    [ '4','Yes'],
]

Идентификаторы в приведенном выше массиве (2,3 и 4) динамически поступают из ответа сервера.Мне нужно посчитать количество записей для конкретного идентификатора.Я не могу понять, как обойти этот массив, чтобы получить ожидаемый результат.Ожидаемый результат:

[{"ID" : "4", Count : "1"},{"ID" : "3", Count : "2"},{"ID" : "2",Count : "3"}]

Обратите внимание, что вывод в порядке возрастания счета.

Это то, что я пытался:

var temp1 = [];
                var temp2 = [];
                var temp3 = [];
                for(var i = 0; i < array.length; ++i){
                     if(array[i][0] == 2){
                        temp1.push(array[i])
                     }
                     if(array[i][0] == 1){
                        temp2.push(array[i])
                     }
                     if(array[i][0] == 3){
                        temp3.push(array[i])
                     }

                }

 var output = [{
                    ID: "2",
                    Count: temp1.length,
                },
                {
                    ID: "1",
                    Count: temp2.length,
                },
                {
                    ID: "3",
                    Count: temp3.length
                }]

console.log(output)

Я считаю,То, как я это делаю, не самый лучший подход, если данные динамические.Как мне сделать это лучше?

Ответы [ 6 ]

7 голосов
/ 30 мая 2019

Комбинированное использование Array.prototype.reduce(), Object.entries(), Array.prototype.sort() и Array.prototype.map() даст это:

const array = [ 
    [ '2','Yes'],
    [ '2','Yes'],
    [ '2','Yes'],
    [ '3','Yes'],
    [ '3','Yes'],
    [ '4','Yes'],
];

const result = Object.entries(array.reduce((a, [id]) => {
  a[id] = (a[id] || 0) + 1;
  return a;
}, {})).map(([ID, Count]) => ({ID, Count}))
       .sort((a, b) => a.Count - b.Count);

console.log(result);
1 голос
/ 30 мая 2019

Вы можете попробовать это.

var array = [ 
    [ '2','Yes'],
    [ '2','Yes'],
    [ '2','Yes'],
    [ '3','Yes'],
    [ '3','Yes'],
    [ '4','Yes'],
];

var y = {};
var z = [];
array.forEach(x=>{      //creating object which will store freq of Id
  if(!y[x[0]]){
    y[x[0]] = 0;
  }
  y[x[0]]++;
});
Object.keys(y).forEach(x=>{   //converting above object to array
  z.push({'ID': x, 'Count':y[x]});
});
console.log(z.sort((a,b) => a.Count - b.Count))//sorting array as per requirement
1 голос
/ 30 мая 2019

Вы можете использовать карту и фильтр для преобразования массива и подсчета вхождений, а затем отсортировать массив по свойству count:

const array = [ 
    [ '2','Yes'],
    [ '2','Yes'],
    [ '2','Yes'],
    [ '3','Yes'],
    [ '3','Yes'],
    [ '4','Yes'],
];

const result = [];
array.forEach( item => {
  if (result.find( id => item[0] === id["ID"])){
    return;
  }
  result.push({"ID": item[0], Count: array.filter(ids =>  ids[0] === item[0]).length});
})

// And then sort it
result.sort( (a,b) => a.Count - b.Count);

console.log(result);
0 голосов
/ 30 мая 2019

Вы можете получить ожидаемый результат также с помощью приведенного ниже фрагмента кода.

var array = [ 
    [ '2','Yes'],
    [ '2','Yes'],
    [ '2','Yes'],
    [ '3','Yes'],
    [ '3','Yes'],
    [ '4','Yes'],
]

var arrMap = {}

array.map(item => {
    if(arrMap[item[0]]){
     arrMap[item[0]]++ 
    }else{
     arrMap[item[0]] = 1
    } 
})

var resultArr = []

for(var keys of Object.keys(arrMap)){
 resultArr.push({"ID":keys,"Count":arrMap[keys]})
}
0 голосов
/ 30 мая 2019

Если вы хотите придерживаться своей петли for, то простой способ - проверить для каждого элемента, включен ли он уже в вывод, и, если да, увеличить счетчик следующим образом:

var array = [
[ '2','Yes'],
[ '2','Yes'],
[ '2','Yes'],
[ '3','Yes'],
[ '3','Yes'],
[ '4','Yes'],
];

var output = [];

for(var i = 0; i < array.length; ++i) {
  if(!output.find(item => item.ID === array[i][0])){
    output.push({'ID': array[i][0], 'Count': 1});
  } else {
    output.find(item => item.ID === array[i][0]).Count += 1;
  }
}
output.sort( (a,b) => a.Count - b.Count)

console.log(output);
0 голосов
/ 30 мая 2019

Попробуйте использовать Array#prototype#reduce

const array = [ 
    [ '2','Yes'],
    [ '2','Yes'],
    [ '2','Yes'],
    [ '3','Yes'],
    [ '3','Yes'],
    [ '4','Yes'],
];

const res = array.reduce((acc, curr) => {
	let foundElement = acc.find(x => x.id === curr[0]);
	
	if (!foundElement) {
		foundElement = {
			id: curr[0],
			count: 1
		};
		
		acc.push(foundElement);
	}
	else {
		foundElement.count += 1;	
	}
	
	return acc;
}, [])
.sort((a, b) => a.count - b.count);

console.log(res);
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...