I don't really understand inject

I think these methods should both do the same thing. The second works,
however in the first I get errors that string is not matched, where
hash is an instance of String not hash

def sequences
self.alignment.split(/\n/).inject(Hash.new) do |hash, line|
id, sequence = line.split(/\s+/,2)
# hash.class == String
hash[id] = sequence
end
end

def sequences
hash = Hash.new
self.alignment.split(/\n/).each do |line|
id, sequence = line.split(/\s+/,2)
# hash.class == Hash
hash[id] = sequence
end
hash
end

On Jun 19, 2008, at 9:13 AM, Mike B. wrote:

I think these methods should both do the same thing. The second works,
however in the first I get errors that string is not matched, where
hash is an instance of String not hash

def sequences
self.alignment.split(/\n/).inject(Hash.new) do |hash, line|
id, sequence = line.split(/\s+/,2)
# hash.class == String
hash[id] = sequence
hash # value of block will be the last expression
end
hash
end

The value of the block becomes the first block parameter in the next
iteration.

-Rob

Rob B. http://agileconsultingllc.com
[email protected]

On Thu, Jun 19, 2008 at 3:13 PM, Mike B. [email protected]
wrote:

end
How inject works is that it passes the block two values:
an accumulator and one of the elements in the enumerable
(one at a time). In each iteration, the accumulator will be the
return value of the block in the previous iteration.

So in your example, if you want the accumulator to be a hash,
your block should return a hash. Try this (untested):

def sequences
self.alignment.split(/\n/).inject(Hash.new) do |hash, line|
id, sequence = line.split(/\s+/,2)
# hash.class == String
hash[id] = sequence
hash # <<< the change
end
end

Hope this helps,

Jesus.

I see, I see, I see.
That solved the problem. Thanks for that help injection!
Ha Ha Ha!

On Jun 19, 2:36 pm, Jesús Gabriel y Galán [email protected]

On Thu, Jun 19, 2008 at 4:08 PM, Mike B. [email protected]
wrote:

I see, I see, I see.
That solved the problem. Thanks for that help injection!
Ha Ha Ha!
Nice one, fortunately you did not ask for help on reduce (which is an
alias of inject) ;).
Robert