[转帖]Ruby中hash方法的汇总_Android, Python及开发编程讨论区_Weblogic技术|Tuxedo技术|中间件技术|Oracle论坛|JAVA论坛|Linux/Unix技术|hadoop论坛_联动北方技术论坛  
网站首页 | 关于我们 | 服务中心 | 经验交流 | 公司荣誉 | 成功案例 | 合作伙伴 | 联系我们 |
联动北方-国内领先的云技术服务提供商
»  游客             当前位置:  论坛首页 »  自由讨论区 »  Android, Python及开发编程讨论区 »
总帖数
1
每页帖数
101/1页1
返回列表
0
发起投票  发起投票 发新帖子
查看: 3457 | 回复: 0   主题: [转帖]Ruby中hash方法的汇总        下一篇 
zhongwei.wang
注册用户
等级:中校
经验:1859
发帖:60
精华:1
注册:2013-12-23
状态:离线
发送短消息息给zhongwei.wang 加好友    发送短消息息给zhongwei.wang 发消息
发表于: IP:您无权察看 2013-12-25 15:13:11 | [全部帖] [楼主帖] 楼主

一。给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




赞(0)    操作        顶端 
总帖数
1
每页帖数
101/1页1
返回列表
发新帖子
请输入验证码: 点击刷新验证码
您需要登录后才可以回帖 登录 | 注册
技术讨论