Use .select! to remove elements from an array
You want to delete elements which doesn't fulfil a condition? Are you going to use a for
loop or .each
iterator?
array.each do |element|
array.delete(element) if element.field < 1
end
It won't work! Some unexpected elements might be still in this array. It's because the array.length
changes.
Use .select!
instead:.
array.select! { |element| element.field >= 1 }
Or as @kv109 suggested, .reject!
:
array.reject! { |element| element.field < 1 }
Written by Maciej Ciemborowicz
Related protips
3 Responses
data:image/s3,"s3://crabby-images/b4661/b4661bc2557e0d775e875306e91af65a3766af11" alt=""
I think Array#reject! is what you are looking for.
over 1 year ago
·
data:image/s3,"s3://crabby-images/41b69/41b695527f8580de577eab480ccdff746481c05f" alt=""
@kv109 Thanks, it's probably the most accurate method:).
over 1 year ago
·
data:image/s3,"s3://crabby-images/3c370/3c370d49f403a7499c5ab4d4a0f4116befcd97bd" alt=""
I'd mention that there's select
and reject
alternatives on enumerable objects that do not mutate the original object (called the "receiver" in the context of message-passing). those come useful when you want to ensure the original object does not change but you need a filtered set of elements.
over 1 year ago
·
Have a fresh tip? Share with Coderwall community!
Post
Post a tip
Best
#Ruby
Authors
Related Tags
#ruby
Sponsored by #native_company# — Learn More
#native_title#
#native_desc#