루비에서 인덱스로 매핑/수집하는 방법은 무엇입니까?
변환하는 가장 쉬운 방법은 무엇입니까?
[x1, x2, x3, ... , xN]
로.
[[x1, 2], [x2, 3], [x3, 4], ... , [xN, N+1]]
루비 1.8.7 또는 1.9를 사용하는 경우 반복기 방법은 다음과 같습니다.each_with_index
블록 없이 호출되면 반환합니다.Enumerator
객체, 호출할 수 있습니다.Enumerable
와 같은 방법map
그래서 당신은 할 수 있습니다.
arr.each_with_index.map { |x,i| [x, i+2] }
1.8.6에서는 다음을 수행할 수 있습니다.
require 'enumerator'
arr.enum_for(:each_with_index).map { |x,i| [x, i+2] }
Ruby에는 Enumerator # with_index(오프셋 = 0)가 있으므로 먼저 Object #to_enum 또는 Array #map을 사용하여 배열을 열거자로 변환합니다.
[:a, :b, :c].map.with_index(2).to_a
#=> [[:a, 2], [:b, 3], [:c, 4]]
루비 1.9.3에는 다음과 같은 연쇄 가능한 방법이 있습니다.with_index
지도에 체인으로 연결할 수 있습니다.
예:
array.map.with_index { |item, index| ... }
상위 난독화 이상:
arr = ('a'..'g').to_a
indexes = arr.each_index.map(&2.method(:+))
arr.zip(indexes)
저는 항상 이 스타일의 구문을 즐겼습니다.
a = [1, 2, 3, 4]
a.each_with_index.map { |el, index| el + index }
# => [1, 3, 5, 7]
호출 중each_with_index
사용 가능한 인덱스로 쉽게 매핑할 수 있는 열거자를 제공합니다.
열거자를 사용하지 않는 1.8.6(또는 1.9)에 대한 두 가지 추가 옵션이 있습니다.
# Fun with functional
arr = ('a'..'g').to_a
arr.zip( (2..(arr.length+2)).to_a )
#=> [["a", 2], ["b", 3], ["c", 4], ["d", 5], ["e", 6], ["f", 7], ["g", 8]]
# The simplest
n = 1
arr.map{ |c| [c, n+=1 ] }
#=> [["a", 2], ["b", 3], ["c", 4], ["d", 5], ["e", 6], ["f", 7], ["g", 8]]
재미있지만 쓸모없는 방법:
az = ('a'..'z').to_a
azz = az.map{|e| [e, az.index(e)+2]}
a = [1, 2, 3]
p [a, (2...a.size+2).to_a].transpose
module Enumerable
def map_with_index(&block)
i = 0
self.map { |val|
val = block.call(val, i)
i += 1
val
}
end
end
["foo", "bar"].map_with_index {|item, index| [item, index] } => [["foo", 0], ["bar", 1]]
저는 종종 이렇게 합니다.
arr = ["a", "b", "c"]
(0...arr.length).map do |int|
[arr[int], int + 2]
end
#=> [["a", 2], ["b", 3], ["c", 4]]
배열의 요소를 직접 반복하는 대신 정수 범위에서 반복하여 배열의 요소를 검색하는 인덱스로 사용합니다.
언급URL : https://stackoverflow.com/questions/4697557/how-to-map-collect-with-index-in-ruby
'programing' 카테고리의 다른 글
Android Firebase, 하나의 하위 개체 데이터만 가져옵니다. (0) | 2023.06.09 |
---|---|
팀 프로비저닝 프로필에 장치 추가 (0) | 2023.06.09 |
R: 목록에 있는 개체 수 (0) | 2023.06.09 |
ORA-00900: 잘못된 SQL 문 - Oracle 10g에서 프로시저를 실행할 때 (0) | 2023.06.09 |
Vuex와의 완벽한 논리적 디커플링 (0) | 2023.06.09 |