http://blackanger.blog.51cto.com/140924/88709
十。 合并两个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}
一。给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