Ruby:排序哈希数组,即使键可能不存在

标签 ruby arrays sorting hash

在 Rails 应用程序中,我有一个哈希数组,我可以轻松地对其进行排序

array_of_hashes.sort_by { |hash| hash[:key_to_sort] }

但是如果不是每个数组成员都有一个键 :key_to_sort 怎么办?然后排序将失败“String 与 nil 的比较失败”。有没有办法让排序继续?或者还有其他方法吗?

最佳答案

这取决于您在散列没有排序键时要执行的操作。我可以想象两种情况:

1) 从排序中排除散列

arr.delete_if { |h| h[:key_to_sort].nil? }.sort_by { |h| h[:key_to_sort] }

2) 将散列放在数组的开头/结尾:

arr.sort_by { |h| h[:key_to_sort] || REALLY_SMALL_OR_LARGE_VALUE }

关于Ruby:排序哈希数组,即使键可能不存在,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7570263/

相关文章:

ruby - 如何将 array.inspect 的输出解析回数组

ruby-on-rails - 如何在 Rails 5 中创建 ActiveRecord 无表模型?

ruby - 识别特定 CSV 输出中的重复项

c++ - 最高和最低平均 C++

c++ - 在 multiset 中维护一个排序的数字列表,在另一个中维护累积和

ruby - 如何使用 RSpec 在 Controller 中实例化实例变量

javascript - 如何调用使用 split 函数创建的数组?

c++ - 如何在C++中预订剧院座位?

javascript - JS 按特定字符串属性对对象数组进行排序(不是升序或降序)

c++ - C++ 中的合并排序实现问题