a, b, c = 0, 1, 2
[a, b, c].find(&:zero?) # => 0
是否有任何方法可以找到块返回false的第一个元素?
[a, b, c].the_method(&:zero?) # => 1
换句话说,它的行为方式与:
相同[a, b, c].reject(&:zero?).first
答案 0 :(得分:10)
有is not,但你可以用干净的方式创建一个:
a = [0,2,1,0,3]
module Enumerable
def first_not(&block)
find{ |x| !block[x] }
end
end
p a.first_not(&:zero?)
#=> 2
......或者是非常有趣的黑客方式:
class Proc
def !
proc{ |o,*a| !self[o,*a] }
end
end
p a.find(&!(:zero?.to_proc))
#=> 2
......或者简洁但非常危险的方式:
class Symbol
def !
proc{ |o,*a| !o.send(self,*a) }
end
end
p a.find(&!:zero?)
#=> 2
但我主张跳过棘手的Symbol#to_proc
用法并说出你想要的内容:
p a.find{ |i| !i.zero? }
#=> 2
答案 1 :(得分:2)
据我所知,没有一种标准方法可以做到这一点(假设find_all和拒绝相互引用,但find没有引用任何东西)。如果您经常需要它(特别是如果拒绝太慢),您可以编写自己的
module Enumerable
def first_reject(&block)
find {|a| not (block.call(a)) }
end
end
答案 2 :(得分:2)
如果您使用的是Ruby 2.0,则可以lazy.reject(&:zero?).first
执行{{1}}而不会影响整个数组的性能损失。