3

I have an array of arrays that also contains hash value , and that array has duplicate arrays that I want to remove. There is an example below :

[[“John, Doe“, "/manager/consumer/123456?status=1", {:data=>{:id=>123456},  :class=>""}],
[“Jane, smith“, "/manager/consumer/7891011?status=1", {:data=>{:id=>7891011},  :class=>""}],
[“William, Smith”, "/manager/consumer/12131415?status=1", {:data=>{:id=>1211415}, :class=>""}],
[“John, Doe“, "/manager/consumer/123456?status=1", {:data=>{:id=>123456}, :class=>""}]]

As we can see there are two arrays that are same(first and last), I would like to remove the duplicate one based on the :id present in the hash inside the array ?

1
  • Which one of each group of "duplicate arrays" do you wish to keep? Commented Jan 7, 2022 at 7:41

1 Answer 1

4

Use uniq method! (ruby >= 1.9.2)

array = [
  ["John, Doe", "/manager/consumer/123456?status=1", {:data=>{:id=>123456},  :class=>""}],
  ["Jane, smith", "/manager/consumer/7891011?status=1", {:data=>{:id=>7891011},  :class=>""}],
  ["William, Smith", "/manager/consumer/12131415?status=1", {:data=>{:id=>1211415}, :class=>""}],
  ["John, Doe", "/manager/consumer/123456?status=1", {:data=>{:id=>123456}, :class=>""}]
]

array.uniq { |_name, _url, hash| hash[:data][:id] }

In case of duplicate of an id it will remove all but the first entry, so you need to think about a situation when the id is the same but rest of the data is not.

NOTE: if you for some reason are running on ruby before 1.9.2, then uniq will ignore the block. For that reason ActiveSupport had uniq_by method (which was removed in version 4.0.2).

Sign up to request clarification or add additional context in comments.

Comments

Your Answer

By clicking “Post Your Answer”, you agree to our terms of service and acknowledge you have read our privacy policy.

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.