我有一个我从数据库调用创建的Assignment对象数组:
@assignments = @player.assignments
我想用这个算一下:
@assignments.count {|x| x.sets == 0.0}
这应该计算0.0集的分配数量。但是,这始终返回@assignments中的对象总数。我检查了那个
@assignments.each {|x| puts x.sets == 0.0}
在所有情况下,都不会返回true。 有线索吗?
编辑>
@assignments.map(&:sets)
=> [35.0, 120.0, 0.0, 0.0, 0.0, 0.0, 0.0, 12.0, 75.0, 0.0, 0.0, 0.0, 0.0]
答案 0 :(得分:23)
最有可能的是,@assignments
不是Array
个实例,而是ActiveRecord::Relation
,请尝试@assignments.class
。如果是这样,count
方法不能按预期工作,它会返回记录数。
尝试
@assignments.where(sets: 0).count
甚至(首先转换为数组)
@assignments.to_a.count {|x| x.sets == 0.0}
答案 1 :(得分:1)
试试这个:
@assignments.select {|x| x if x.sets == 0.0}.count
由于
答案 2 :(得分:0)
查看count或者只计算对象的数量(在内部检查每个对象就像对象将存在一样,如果nill
将返回false,它将返回true,所以实际上它会计算{的数量块返回的{1}},如果你想计算你的条件成立的次数,我建议你尝试使用仅在ruby中为这些类型的计算做的true
迭代器。
就像这样
inject