【发布时间】:2011-04-06 15:41:18
【问题描述】:
假设我有一个数组
[0, 132, 432, 342, 234]
摆脱第一个元素的最简单方法是什么? (0)
【问题讨论】:
-
'shift' 是 pop 而 'unshift' 是 push。其中 shift 接受要弹出的参数数量
标签: ruby-on-rails ruby
假设我有一个数组
[0, 132, 432, 342, 234]
摆脱第一个元素的最简单方法是什么? (0)
【问题讨论】:
标签: ruby-on-rails ruby
.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) => []
shift 会在原地改变数组并返回移位后的元素(如果数组为空,则返回nil)
在数组上使用shift 方法
>> x = [4,5,6]
=> [4, 5, 6]
>> x.shift
=> 4
>> x
=> [5, 6]
如果要删除 n 个起始元素,可以使用 x.shift(n)
【讨论】:
“pop”数组的第一个元素称为“shift”(“unshift” 是添加一个元素的操作 在数组前面)。
【讨论】:
nil。如另一个答案中所述,请参阅drop 以获取替代方案。
[0, 132, 432, 342, 234][1..-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]
正如 cmets 中所写,不改变原始列表的优点是。
【讨论】:
(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
【讨论】:
【讨论】:
您可以使用 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
两者都可以工作
【讨论】: