Type:
Class

A class which allows both internal and external iteration.

An Enumerator can be created by the following methods.

  • Kernel#to_enum

  • Kernel#enum_for

  • ::new

Most methods have two forms: a block form where the contents are evaluated for each item in the enumeration, and a non-block form which returns a new Enumerator wrapping the iteration.

enumerator = %w(one two three).each
puts enumerator.class # => Enumerator

enumerator.each_with_object("foo") do |item, obj|
  puts "#{obj}: #{item}"
end

# foo: one
# foo: two
# foo: three

enum_with_obj = enumerator.each_with_object("foo")
puts enum_with_obj.class # => Enumerator

enum_with_obj.each do |item, obj|
  puts "#{obj}: #{item}"
end

# foo: one
# foo: two
# foo: three

This allows you to chain Enumerators together. For example, you can map a list's elements to strings containing the index and the element as a string via:

puts %w[foo bar baz].map.with_index { |w, i| "#{i}:#{w}" }
# => ["0:foo", "1:bar", "2:baz"]

An Enumerator can also be used as an external iterator. For example, #next returns the next value of the iterator or raises StopIteration if the Enumerator is at the end.

e = [1,2,3].each   # returns an enumerator object.
puts e.next   # => 1
puts e.next   # => 2
puts e.next   # => 3
puts e.next   # raises StopIteration

You can use this to implement an internal iterator as follows:

def ext_each(e)
  while true
    begin
      vs = e.next_values
    rescue StopIteration
      return $!.result
    end
    y = yield(*vs)
    e.feed y
  end
end

o = Object.new

def o.each
  puts yield
  puts yield(1)
  puts yield(1, 2)
  3
end

# use o.each as an internal iterator directly.
puts o.each {|*x| puts x; [:b, *x] }
# => [], [:b], [1], [:b, 1], [1, 2], [:b, 1, 2], 3

# convert o.each to an external iterator for
# implementing an internal iterator.
puts ext_each(o.to_enum) {|*x| puts x; [:b, *x] }
# => [], [:b], [1], [:b, 1], [1, 2], [:b, 1, 2], 3
each_with_index
  • References/Ruby on Rails/Ruby/Classes/Enumerator

e.each_with_index {|(*args), idx| ... }e.each_with_index Instance Public methods Same

2025-01-10 15:47:30
zip
  • References/Ruby on Rails/Ruby/Classes/Enumerator/Enumerator::Lazy

zip(*args) Instance Public methods

2025-01-10 15:47:30
map
  • References/Ruby on Rails/Ruby/Classes/Enumerator/Enumerator::Lazy

map() Instance Public methods

2025-01-10 15:47:30
take
  • References/Ruby on Rails/Ruby/Classes/Enumerator/Enumerator::Lazy

take(p1) Instance Public methods

2025-01-10 15:47:30
slice_before
  • References/Ruby on Rails/Ruby/Classes/Enumerator/Enumerator::Lazy

slice_before(*args) Instance Public methods

2025-01-10 15:47:30
collect_concat
  • References/Ruby on Rails/Ruby/Classes/Enumerator/Enumerator::Lazy

lazy.flat_map { |obj| block } â a_lazy_enumerator Instance Public methods Returns

2025-01-10 15:47:30
each
  • References/Ruby on Rails/Ruby/Classes/Enumerator

enum.each {...} Instance Public methods Iterates over the block according to

2025-01-10 15:47:30
collect
  • References/Ruby on Rails/Ruby/Classes/Enumerator/Enumerator::Lazy

collect() Instance Public methods

2025-01-10 15:47:30
lazy
  • References/Ruby on Rails/Ruby/Classes/Enumerator/Enumerator::Lazy

lazy() Instance Public methods

2025-01-10 15:47:30
enum_for
  • References/Ruby on Rails/Ruby/Classes/Enumerator/Enumerator::Lazy

lzy.enum_for(method = :each, *args) â lazy_enumlzy.enum_for(method = :each, *args){|*args| block} â lazy_enum

2025-01-10 15:47:30