Ruby 1.9.2 リファレンスマニュアル > ライブラリ一覧 > library _builtin > module Enumerable > zip
zip(*lists) -> [[object]]self と引数に渡した配列の各要素からなる配列の配列を生成して返します。 生成される配列の要素数は self の要素数と同じです。
例:
p [1,2,3].zip([4,5,6], [7,8,9])
# => [[1, 4, 7], [2, 5, 8], [3, 6, 9]]
p [1,2].zip([:a,:b,:c], [:A,:B,:C,:D])
# => [[1, :a, :A], [2, :b, :B]]
p (1..5).zip([:a,:b,:c], [:A,:B,:C,:D])
# => [[1, :a, :A], [2, :b, :B],
# [3, :c, :C], [4, nil, :D], [5, nil, nil]]
zip(*lists) {|v1, v2, ...| ...} -> nilzip をブロック付きで呼び出した場合は、 self と引数に渡した配列の各要素を順番にブロックに渡します。
常に nil を返します。
例:
p [1,2,3].zip([4,5,6], [7,8,9]) {|ary|
p ary
}
# => [1, 4, 7]
# [2, 5, 8]
# [3, 6, 9]
# nil