답변:
a = [0,1,2,3]
a.drop(1)
# => [1, 2, 3]
a
# => [0,1,2,3]
그리고 추가적으로 :
[0,1,2,3].drop(2)
=> [2, 3]
[0,1,2,3].drop(3)
=> [3]
[].drop(1) => []
shift배열을 변경하고 이동 된 요소를 반환합니다 (또는 nil배열이 비어있는 경우)
[0, 132, 432, 342, 234][1..-1]
=> [132, 432, 342, 234]
달리 shift또는 slice이것은 수정 된 배열을 반환합니다 (한 라이너에 유용합니다).
[][1..-1] => nil및 not이 반환 []됩니다.
[1,2,3].shift한 라이너는?
arry[1..-1] || []. 그러나 arry.drop (1)이 더 좋습니다.
이것은 매우 깔끔합니다.
head, *tail = [1, 2, 3, 4, 5]
#==> head = 1, tail = [2, 3, 4, 5]
주석에 쓰여 있듯이 원본 목록을 변경하지 않는 이점이 있습니다.
(let ((head (car mylist)) (tail (cdr mylist)) ...)
header, *properties = CSV.read(file_path,encoding: 'ISO-8859-1')
시프트 방식 사용
array.shift(n) => Remove first n elements from array
array.shift(1) => Remove first element
첫 번째 요소를 삭제하는 Array.delete_at (0) 메소드를 사용할 수 있습니다.
x = [2,3,4,11,0]
x.delete_at(0) unless x.empty? # [3,4,11,0]
unless x.empty?합니다. nil인덱스가 범위를 벗어나면 단순히 반환 됩니다.