Alex学Ruby[ Hash方法汇总 ]
版权声明:原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://blackanger.blog.51cto.com/140924/88709 |
一。给Hash添加默认值 : h = {1,2,3,4} #=> {1 => 2, 3 => 4} h.default = 7 h[1] #=> 2 h[3] #=> 4 h[4] #=> 7 h[5] #=> 7二。给Hash添加key-value对: h = {} #=> {} h.store("a",1) #=> 1 h["a"] #=> 1 h.fetch("a") #=> 1 h["b"] = 2 #=> 2 h["b"] #=> 2 p h #=> {"a"=>1, "b"=>2}store和[]= 方法是别名的关系, fetch和[]方法是别名的关系。 三。清除Hash的key-value对: h = {:a => 1, :b => 2} 删除全部的k-v对,有两种方法: 给hash赋空值 用clear方法 (这种方法更快一点) shift方法随机删除k-v对。 h = {:a => 1, :b => 2, :c => 3} h.shift #=> [:a, 1] h #=> {:b=>2, :c=>3} a = h.shift #=> [:c, 3] a #=> [:c, 3]delete, delete_if, reject,reject! 方法删除指定的k-v对: h = {:a => 1, :b => 2} h.delete(:a) #=> 1 h #=> {:b=>2} h = {:a => 1, :b => 2} #=> {:a=>1, :b=>2} h.delete_if {|k,v| v != 3} #=> {} h #=> {} h = {:a => 1, :b => 2} #=> {:a=>1, :b=>2} h.delete_if {|k,v| v != 1} #=> {:a=>1} h = {:a => 1, :b => 2} #=> {:a=>1, :b=>2} h.reject {|k,v| v!=2} #=> {:b=>2} h #=> {:a=>1, :b=>2}reject方法相当于dup.delete_if{} 四。颠倒Hash的k-v对。 h = {:a => 1,:b => 1} #=> {:a=>1, :b=>1} x = h.invert #=> {1=>:b}invert方法可以颠倒Hash的键-值,可是因为Hash键的唯一性,可能会发生上例那样的数据丢失! 五。 Hash的迭代: 有each, each_key, each_value ,each_pair(each方法的别名) 不举例了。 六。检测Hash中的key,value: 检测是否有key: has_key?(include? 别名, 只能判断key! ) ,key?, member? 检测是否有value: has_value? value? 七。将散列转换为数组: h = {:a => 1, :b => 2} h.to_a #=> [[:a, 1], [:b, 2]] 转换为一个二维数组。 h.keys #=> [:a, :b] h.values #=> [1,2]下面的方法有用点: h = {:a => 1, :b => '2', :c => 5} h.values_at(:a,:b) #=> [1, “2”] 根据指定的key返回对应values的数组八。根据条件选择key-value对: h.detect {|k,v| v == "2"} #=> [:b, "2"]detect和find是别名关系,是Enumerable模块里的方法,Hash类mixin这个模块,所以也可以用。select 方法,别名是find_all,可以返回多个匹配的k-v对: h.select {|k,v| v.is_a?(Integer)} #=> [[:a, 1], [:c, 5]]九。 Hash的排序: 可以直接用sort方法,不过会返回一个二维数组。 值得注意的是,当Hash的key是Symbol类型的时候,sort方法会出错。 十。 合并两个Hash: 使用merge方法,( merge!和update是别名关系 (thx Beck) ) 。 h1 = {:a => 1, :b => 2} #=> {:a=>1, :b=>2} h2 = {:b => 3, :d => 3} #=> {:d=>3, :b=>3} h1.merge h2 #=> {:a=>1, :d=>3, :b=>3} h2.merge h1 #=> {:a=>1, :d=>3, :b=>2}注意看:b值的变化。 当然我们可以使用block来改变这一结局: h1.merge h2 do |k,old,new| old < new ? old : new end #=> {:a=>1, :d=>3, :b=>2} h1.merge h2 do |k,old,new| p old p new end #=>2 #=>3(当然我们可以使用rails里active_support实现的revert_merge来实现上述效果)。 十一。 数组转换为Hash: 当数组元素为偶数个数的时候: arr = %w[a b c d] #=> ["a", "b", "c", "d"] h = Hash[*arr] #=> {"a"=>"b", "c"=>"d"}此时数组必须为偶数个元素。 十二。 当Hash的key是动态变化的时候: x = [1,2] #=> [1, 2] h = {x => 2} #=> {[1, 2]=>2} h[x] #=> 2 x[0] = 5 #=> 5 h[x] #=> nil h.rehash #=> {[5, 2]=>2} h[x] #=> 2本文出自 “{ :Alex Space => " Ruby Notes " }” 博客,请务必保留此出处http://blackanger.blog.51cto.com/140924/88709 本文出自 51CTO.COM技术博客 |



h = {1,2,3,4} #=> {1 => 2, 3 => 4}
blackanger
博客统计信息
热门文章
最新评论
友情链接

