假设我有一个数组
[0, 132, 432, 342, 234]
最简单的方法是如何摆脱第一个元素?(0)
假设我有一个数组
[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]
[].drop(1) => []
。 - fearless_foolshift
则会直接在原数组上进行修改,并返回移除的元素(如果数组为空,则返回nil
)。 - yuval使用数组的shift
方法。
>> x = [4,5,6]
=> [4, 5, 6]
>> x.shift
=> 4
>> x
=> [5, 6]
如果你想要移除前n个元素,可以使用x.shift(n)
从数组中弹出第一个元素被称为"shift"(在数组前面添加一个元素的操作为"unshift")。
nil
。如其他答案所述,请参考drop
以获取替代方法。 - Jay[0, 132, 432, 342, 234][1..]
=> [132, 432, 342, 234]
所以与 shift
或 slice
不同的是,这个方法返回一个新数组,不会修改原始数组(适用于一行代码的情况)。
[][1..-1] => nil
而不是[]
。 - Mohamad[1,2,3].shift
不就是一行代码吗? - thekingoftrutharry[1..-1] || []
。但使用arry.drop(1)更好。 - fearless_fool这相当不错:
head, *tail = [1, 2, 3, 4, 5]
#==> head = 1, tail = [2, 3, 4, 5]
正如评论中所写,不改变原始列表有一个优势。
(let ((head (car mylist)) (tail (cdr mylist)) ...)
- thekingoftruthheader,*properties = CSV.read(file_path, encoding: 'ISO-8859-1')
请将翻译文本仅返回。 - juliangonzalez使用 shift 方法
array.shift(n) => Remove first n elements from array
array.shift(1) => Remove first element
or a.delete_at 0
x = [2,3,4,11,0]
x.delete_at(0) unless x.empty? # [3,4,11,0]
unless x.empty?
是不必要的。如果索引超出范围,它只会返回 nil
。 - webninja您可以使用:
arr - [arr[0]]
或者
arr - [arr.shift]
arr.shift(1)