浙江省高等学校教师教育理论培训

微信搜索“毛凌志岗前心得”小程序

  博客园  :: 首页  :: 新随笔  :: 联系 :: 订阅 订阅  :: 管理

2010-01-18

Ruby -- Hash方法汇总

文章分类:Ruby编程

一。给Hash添加默认值 :

Ruby代码 
  1. h = {1,2,3,4}   #=> {1 => 2, 3 => 4}  
  2. h.default = 7  
  3. h[1]                #=>  2  
  4. h[3]                #=>  4  
  5. h[4]                #=>  7  
  6. h[5]                #=>  7  
 




二。给Hash添加key-value对:

Ruby代码 
  1. h = {}                     #=> {}  
  2. h.store("a" ,1)         #=> 1  
  3. h["a" ]                     #=> 1  
  4. h.fetch("a" )            #=> 1  
  5. h["b" ] = 2               #=> 2  
  6. h["b" ]                     #=> 2  
  7. p  h                        #=> {"a" =>1, "b" =>2}  
 


store和[]= 方法是别名的关系,  fetch和[]方法是别名的关系。


三。清除Hash的key-value对:

Ruby代码 
  1. h = {:a => 1, :b => 2}  
 



删除全部的k-v对,有两种方法:
给hash赋空值
用clear方法 (这种方法更快一点)

shift方法随机删除k-v对。

Ruby代码 
  1. h = {:a => 1, :b => 2, :c => 3}  
  2. h.shift             #=> [:a, 1]  
  3. h                     #=> {:b=>2, :c=>3}  
  4. a = h.shift       #=> [:c, 3]  
  5. a                     #=> [:c, 3]  
 



delete, delete_if, reject,reject! 方法删除指定的k-v对:

Ruby代码 
  1. h = {:a => 1, :b => 2}  
  2. h.delete(:a)                     #=> 1  
  3. h                                     #=> {:b=>2}  
  4. h = {:a => 1, :b => 2}      #=> {:a=>1, :b=>2}  
  5. h.delete_if {|k,v| v != 3}   #=> {}  
  6. h                                     #=> {}  
  7. h = {:a => 1, :b => 2}      #=> {:a=>1, :b=>2}  
  8. h.delete_if {|k,v| v != 1}   #=> {:a=>1}  
  9. h = {:a => 1, :b => 2}      #=> {:a=>1, :b=>2}  
  10. h.reject {|k,v| v!=2}          #=> {:b=>2}  
  11. h                                     #=> {:a=>1, :b=>2}  
 


reject方法相当于dup.delete_if{}



四。颠倒Hash的k-v对。

Ruby代码 
  1. h = {:a => 1,:b => 1}        #=> {:a=>1, :b=>1}  
  2. 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?

七。将散列转换为数组:

 
Ruby代码 
  1. h = {:a => 1, :b => 2}  
  2. h.to_a         #=> [[:a, 1], [:b, 2]]   转换为一个二维数组。  
  3. h.keys         #=> [:a, :b]  
  4. h.values      #=> [1,2]  
 


   下面的方法有用点:

Ruby代码 
  1. h = {:a => 1, :b => '2':c => 5}  
  2. h.values_at(:a,:b)    #=> [1, “2”]    根据指定的key返回对应values的数组  
 



八。根据条件选择key-value对:

  
Ruby代码 
  1. h.detect {|k,v| v == "2" }             #=> [:b, "2" ]  
 


   detect和find是别名关系,是Enumerable模块里的方法,Hash类mixin这个模块,所以也可以用。select 方法,别名是find_all,可以返回多个匹配的k-v对:

 
Ruby代码 
  1. h.select {|k,v| v.is_a?(Integer)}   #=> [[:a, 1], [:c, 5]]  
 



九。 Hash的排序:
    可以直接用sort方法,不过会返回一个二维数组。
    值得注意的是,当Hash的key是Symbol类型的时候,sort方法会出错。


十。 合并两个Hash:
   使用merge方法,( merge!和update是别名关系 (thx Beck) )  。

 
Ruby代码 
  1. h1 = {:a => 1, :b => 2}          #=> {:a=>1, :b=>2}  
  2. h2 = {:b => 3, :d => 3}          #=> {:d=>3, :b=>3}  
  3. h1.merge h2                         #=> {:a=>1, :d=>3, :b=>3}  
  4. h2.merge h1                         #=> {:a=>1, :d=>3, :b=>2}  
 


  注意看:b值的变化。 
 当然我们可以使用block来改变这一结局:

Ruby代码 
  1.   h1.merge h2 do  |k,old,new |  
  2.       old < new ? old : new  
  3.   end  
  4. #=> {:a=>1, :d=>3, :b=>2}  
  5. h1.merge h2 do |k,old,new |  
  6.     p old  
  7.     p new  
  8. end  
  9. #=>2  
  10. #=>3  
 


(当然我们可以使用rails里active_support实现的revert_merge来实现上述效果)。

十一。 数组转换为Hash:
  当数组元素为偶数个数的时候:

  
Ruby代码 
  1. arr = %w[a b c d]         #=> ["a" , "b" , "c" , "d" ]  
  2. h = Hash[*arr]              #=> {"a" =>"b" , "c" =>"d" }  
 


   此时数组必须为偶数个元素。


十二。 当Hash的key是动态变化的时候:

Ruby代码 
  1. x = [1,2]                  #=> [1, 2]  
  2. h = {x => 2}            #=> {[1, 2]=>2}  
  3. h[x]                         #=> 2  
  4. x[0] = 5                   #=> 5  
  5. h[x]                         #=> nil  
  6. h.rehash                 #=> {[5, 2]=>2}  
  7. h[x]                         #=> 2  

posted on 2010-11-19 09:50  lexus  阅读(480)  评论(0编辑  收藏  举报