In aggiunta al metodo Array#each_with_index
di Ruby 1.8, molti metodi di enumerazione in Ruby 1.9 restituiscono un Enumeratore quando viene chiamato senza blocco; quindi è possibile chiamare il metodo with_index
di avere l'enumeratore passano anche lungo l'indice:
irb(main):001:0> a = *('a'..'g')
#=> ["a", "b", "c", "d", "e", "f", "g"]
irb(main):002:0> a.map
#=> #<Enumerator:0x28bfbc0>
irb(main):003:0> a.select
#=> #<Enumerator:0x28cfbe0>
irb(main):004:0> a.select.with_index{ |c,i| i%2==0 }
#=> ["a", "c", "e", "g"]
irb(main):005:0> Hash[ a.map.with_index{ |c,i| [c,i] } ]
#=> {"a"=>0, "b"=>1, "c"=>2, "d"=>3, "e"=>4, "f"=>5, "g"=>6}
Se volete map.with_index
o select.with_index
(o simile) sotto Rubino 1.8.x, è possibile fare questo noioso-ma- metodo veloce:
i = 0
a.select do |c|
result = i%2==0
i += 1
result
end
o ci si può divertire più funzionale:
a.zip((0...a.length).to_a).select do |c,i|
i%2 == 0
end.map{ |c,i| c }
Qual è la tua domanda? Non capisco cosa stai chiedendo. –
Ah, sapevo che era vago. Come tenere traccia delle variabili del contatore. – s84