Answered on: Monday 24 June, 2024 / Duration: 15 min read
I have an object that contains an array of objects.
I'm wondering what is the best method to remove duplicate objects from an array. So for example, obj.arr
would become...
Tags: javascript, arrays, object, duplicates , Popularity :6/10
Solution 1:
How about with some ES6 magic?
obj.arr = obj.arr.filter((value, index, self) => index === self.findIndex((t) => ( t.place === value.place && t.name === value.name )))
A more generic solution would be:
const uniqueArray = obj.arr.filter((value, index) => { const _value = JSON.stringify(value); return index === obj.arr.findIndex(obj => { return JSON.stringify(obj) === _value; });});
Using the above property strategy instead of JSON.stringify
:
const isPropValuesEqual = (subject, target, propNames) => propNames.every(propName => subject[propName] === target[propName]);const getUniqueItemsByProperties = (items, propNames) => items.filter((item, index, array) => index === array.findIndex(foundItem => isPropValuesEqual(foundItem, item, propNames)) );
You can add a wrapper if you want the propNames
property to be either an array or a value:
const getUniqueItemsByProperties = (items, propNames) => { const propNamesArray = Array.from(propNames); return items.filter((item, index, array) => index === array.findIndex(foundItem => isPropValuesEqual(foundItem, item, propNamesArray)) );};
allowing both getUniqueItemsByProperties('a')
and getUniqueItemsByProperties(['a']);
Explanation
- Start by understanding the two methods used:
- Next take your idea of what makes your two objects equal and keep that in mind.
- We can detect something as a duplicate, if it satisfies the criterion that we have just thought of, but its position is not at the first instance of an object with the criterion.
- Therefore we can use the above criterion to determine if something is a duplicate.
Solution 2:
One liners with filter()
(Preserves order)
If you have some identifier in the objects which signifies uniqueness (e.g. id
), then we can use filter()
with findIndex()
to work through the list and verify that the index of each object with that id
value matches only itself. This means that there's only one such object in the list, i.e. no duplicates.
myArr.filter((obj1, i, arr) => arr.findIndex(obj2 => (obj2.id === obj1.id)) === i)
(Note that this solution keeps the first instance of detected duplicates in the result. You can instead take the last instance by replacing findIndex
with findLastIndex
in the above.)
If the order is not important, then map solutions will be faster: Solution with map
The above format can be applied to other cases by altering how we check for duplicates (i.e. replacing obj2.id === obj1.id
with something else).
Unique by multiple properties (e.g. place
and name
, as in the question)
myArr.filter((obj1, i, arr) => arr.findIndex(obj2 => ['place', 'name'].every(key => obj2[key] === obj1[key]) ) === i)
Unique by all properties
myArr.filter((obj1, i, arr) => arr.findIndex(obj2 => JSON.stringify(obj2) === JSON.stringify(obj1) ) === i)
Caveats:
- This may get slow, depending on object & array sizes
JSON.stringify()
key order is generally consistent, but is only guaranteed in ES2015 and later- This means that your mileage may vary, and you may want to prefer something more robust (like comparing specific keys)
Solution 3:
One way to remove duplicate objects from an array is by using the filter method in JavaScript. Here is an example code snippet to achieve this:
javascript
// Sample object containing an array of objects
let obj = {
arr: [
{ id: 1, name: 'John' },
{ id: 2, name: 'Jane' },
{ id: 1, name: 'John' }, // duplicate object
{ id: 3, name: 'Alice' }
]
};</p><p>// Remove duplicate objects from the array
obj.arr = obj.arr.filter((item, index, self) =>
index === self.findIndex((t) => (
t.id === item.id && t.name === item.name
))
);</p><p>console.log(obj.arr);
In this code snippet, the filter method is used to iterate over the array and only keep the objects that pass the condition provided in the callback function. The condition checks if the current object's id and name properties match the first occurrence of that object in the array using findIndex.
When you run this code snippet, the output will be:
[
{ id: 1, name: 'John' },
{ id: 2, name: 'Jane' },
{ id: 3, name: 'Alice' }
]
As you can see, the duplicate object { id: 1, name: 'John' } has been removed from the array.
Solution 4:
Using ES6+ in a single line you can get a unique list of objects by key:
const key = 'place';const unique = [...new Map(arr.map(item => [item[key], item])).values()]
It can be put into a function:
function getUniqueListBy(arr, key) { return [...new Map(arr.map(item => [item[key], item])).values()]}
Here is a working example:
const arr = [ {place: "here", name: "x", other: "other stuff1" }, {place: "there", name: "x", other: "other stuff2" }, {place: "here", name: "y", other: "other stuff4" }, {place: "here", name: "z", other: "other stuff5" }]function getUniqueListBy(arr, key) { return [...new Map(arr.map(item => [item[key], item])).values()]}const arr1 = getUniqueListBy(arr, 'place')console.log("Unique by place")console.log(JSON.stringify(arr1))console.log("\nUnique by name")const arr2 = getUniqueListBy(arr, 'name')console.log(JSON.stringify(arr2))
How does it work
First the array is remapped in a way that it can be used as an input for a Map.
arr.map(item => [item[key], item]);
which means each item of the array will be transformed in another array with 2 elements; the selected key as first element and the entire initial item as second element, this is called an entry (ex. array entries, map entries). And here is the official doc with an example showing how to add array entries in Map constructor.
Example when key is place:
[["here", {place: "here", name: "x", other: "other stuff1" }], ...]
Secondly, we pass this modified array to the Map constructor and here is the magic happening. Map will eliminate the duplicate keys values, keeping only last inserted value of the same key.Note: Map keeps the order of insertion. (check difference between Map and object)
new Map(entry array just mapped above)
Third we use the map values to retrieve the original items, but this time without duplicates.
new Map(mappedArr).values()
And last one is to add those values into a fresh new array so that it can look as the initial structure and return that:
return [...new Map(mappedArr).values()]
Solution 5:
To remove duplicate objects from an array, you can use the filter() method in combination with the map() and indexOf() methods in JavaScript. Here's an example:
First, let's assume you have the following object:
javascript
let obj = {
arr: [
{ id: 1, name: 'John' },
{ id: 2, name: 'Jane' },
{ id: 1, name: 'John' }, // duplicate object
{ id: 3, name: 'Bob' },
{ id: 2, name: 'Jane' } // duplicate object
]
};
To remove duplicates from obj.arr, you can do the following:
javascript
obj.arr = obj.arr.filter((value, index, self) => {
return self.findIndex(v => (v.id === value.id && v.name === value.name)) === index;
});
Explanation:
* filter() creates a new array with all elements that pass the test implemented by the provided function.
* value is the current element being processed in the array.
* index is the index of the current element being processed in the array.
* self is the array that filter() was called upon.
* We check if the current object (value) exists earlier in the array (using findIndex()) and if it does, we skip it (using return).
* If the current object doesn't exist earlier in the array, it is added to the new array (because we return true for those objects).
After running the above code, obj.arr will contain only unique objects with no duplicates:
javascript
console.log(obj);
/*
{
arr: [
{ id: 1, name: 'John' },
{ id: 2, name: 'Jane' },
{ id: 3, name: 'Bob' }
]
}
*/
Solution 6:
Finding Duplicates in an Array
Identifying duplicate objects in an array can be achieved using various techniques. One common approach is to utilize the indexOf() method. Here's an example:
const obj = {
arr: [
{ id: 1, name: "John" },
{ id: 2, name: "Jane" },
{ id: 1, name: "John" },
{ id: 3, name: "Michael" },
],
};</p><p>const duplicates = [];
for (let i = 0; i < obj.arr.length; i++) {<br> const index = obj.arr.indexOf(obj.arr[i], i + 1);
if (index !== -1) {
duplicates.push(obj.arr[index]);
}
}</p><p>console.log(duplicates); // [{ id: 1, name: "John" }]
This code iterates through the arr array and searches for duplicates using the indexOf() method. If a duplicate is found at an index greater than the current index, it is added to the duplicates array.
Removing Duplicates from an Array
Once the duplicates are identified, you can remove them from the array using several methods. Here's an example using the filter() method:
obj.arr = obj.arr.filter((item) => {
return duplicates.indexOf(item) === -1;
});</p><p>console.log(obj.arr); // [{ id: 2, name: "Jane" }, { id: 3, name: "Michael" }]
The filter() method creates a new array with only the elements that pass the specified condition. In this case, the condition checks if the current item is not present in the duplicates array. This effectively removes the duplicates from the original arr array.
Another option for removing duplicates is to use the Set data structure:
const uniqueArr = [...new Set(obj.arr)];</p><p>console.log(uniqueArr); // [{ id: 2, name: "Jane" }, { id: 3, name: "Michael" }]
The Set constructor creates a new set with unique elements from the iterable provided. In this case, we pass the obj.arr array, and the ... operator is used to spread the values into a new array. This approach ensures that only unique elements are retained in the resulting array.
Output
The output of both methods is:
[
{ id: 2, name: "Jane" },
{ id: 3, name: "Michael" }
]
This demonstrates that the duplicate object { id: 1, name: "John" } has been removed from the array, leaving only the unique elements.
More Articles :
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : android, localization , Popularity : 9/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : java, java-8, nullable, option-type , Popularity : 3/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : user-interface, model-view-controller, design-patterns, terminology, mvp , Popularity : 10/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : json, go, marshalling , Popularity : 9/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : python, progress-bar , Popularity : 4/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : python, unit-testing, pytest , Popularity : 7/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : java, image, swing, jpanel , Popularity : 6/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : html, meta-tags, doctype , Popularity : 6/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : javascript, jquery, xml, json, format-conversion , Popularity : 10/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : sql, mysql, database, local-variables, user-defined-variables , Popularity : 3/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : unit-testing, testing, language-agnostic , Popularity : 7/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : python, arguments, optional-parameters, named-parameters , Popularity : 3/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : android-studio, android-assets , Popularity : 7/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : python, pandas, dataframe, multi-index , Popularity : 7/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : java, static, program-entry-point , Popularity : 10/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : mysql, sql, interop, case-sensitive, string-comparison , Popularity : 5/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : angular, angular2-services , Popularity : 10/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : python, exception, variables , Popularity : 10/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : security, language-agnostic, encryption, hash, passwords , Popularity : 5/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : python, django, django-models, group-by , Popularity : 8/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : c#, .net, performance, file-io, text-files , Popularity : 4/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : ios, hyperlink, uilabel, nsattributedstring, uitapgesturerecognizer , Popularity : 5/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : php, stdclass , Popularity : 8/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : ios, iphone, screenshot , Popularity : 10/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : javascript, jquery, query-string , Popularity : 8/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : java, path, environment-variables, command-prompt, javac , Popularity : 9/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : sql, sorting, sql-order-by, multiple-columns , Popularity : 7/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : javascript, reactjs , Popularity : 5/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : javascript, jquery, asp.net, asp.net-ajax, jquery-events , Popularity : 7/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : json , Popularity : 6/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : javascript, arrays, unique, array-of-dict , Popularity : 7/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : .net, linq, performance, join, linq-to-dataset , Popularity : 10/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : android, reverse-engineering, proguard, api-key , Popularity : 3/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : javascript, html, file-upload, mime-types , Popularity : 7/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : python, indentation, python-2.x , Popularity : 7/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : javascript, html, css, stylesheet , Popularity : 7/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : c++, reference, stl, stdvector, container-data-type , Popularity : 7/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : android, image, android-intent, gallery , Popularity : 7/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : sql, sql-server, oracle, t-sql, plsql , Popularity : 4/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : python, file, io , Popularity : 3/10
Read More ...
Answered on: Monday 24 June, 2024 / Duration: 5-10 min read
Programming Language : c#, class, static , Popularity : 3/10
Read More ...