假设我有一个数组
[0, 132, 432, 342, 234]
摆脱第一个元素的最简单方法是什么? (0)
使用 .drop(1)。
这样做的好处是返回一个删除了第一个元素的新数组,而不是使用 .shift
,它返回删除的元素,而不是删除第一个元素的数组。
注意:它不会影响/改变原始数组。
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]
对数组使用 shift
方法
>> x = [4,5,6]
=> [4, 5, 6]
>> x.shift
=> 4
>> x
=> [5, 6]
如果要删除 n 个起始元素,可以使用 x.shift(n)
[0, 132, 432, 342, 234][1..]
=> [132, 432, 342, 234]
因此,与 shift
或 slice
不同,它返回一个新数组,保持原始数组不变(对一个衬里有用)。
[][1..-1] => nil
而不是 []
。
[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')
或a.delete_at 0
使用移位方法
array.shift(n) => Remove first n elements from array
array.shift(1) => Remove first element
https://ruby-doc.org/core-2.2.0/Array.html#method-i-shift
您可以使用 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
。
您可以使用:
arr - [arr[0]]
或者
arr - [arr.shift]
或者干脆
arr.shift(1)
您可以使用:
a.delete(a[0])
a.delete_at 0
两者都可以工作
[].drop(1) => []
shift
会改变数组并返回移位的元素(如果数组为空,则返回nil
)