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

#将数组转为一个Hash
@titles=Hash.new
@field_titles.each do |f|
@titles[f.code] = f.name
end

十二。 当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

ruby--Hash方法汇总的更多相关文章

  1. 在数据库各种状态下查询DBID的五大类十种方法汇总

    关于DBID: DBID是DataBase IDentifier的缩写,意思就是数据库的唯一标识符. 这个DBID在数据文件头和控制文件都是存在的,可以用于标示数据文件的归属. 对于不同数据库来说,D ...

  2. 八大排序方法汇总(选择排序,插入排序-简单插入排序、shell排序,交换排序-冒泡排序、快速排序、堆排序,归并排序,计数排序)

    2013-08-22 14:55:33 八大排序方法汇总(选择排序-简单选择排序.堆排序,插入排序-简单插入排序.shell排序,交换排序-冒泡排序.快速排序,归并排序,计数排序). 插入排序还可以和 ...

  3. 雷林鹏分享:Ruby CGI方法

    Ruby CGI方法 以下为CGI类的方法列表: 序号方法描述 1CGI::new([ level="query"]) 创建 CGI 对象.query可以是以下值: query: ...

  4. 编程中遇到的Python错误和解决方法汇总整理

    这篇文章主要介绍了自己编程中遇到的Python错误和解决方法汇总整理,本文收集整理了较多的案例,需要的朋友可以参考下   开个贴,用于记录平时经常碰到的Python的错误同时对导致错误的原因进行分析, ...

  5. 你真的会玩SQL吗?实用函数方法汇总

    你真的会玩SQL吗?系列目录 你真的会玩SQL吗?之逻辑查询处理阶段 你真的会玩SQL吗?和平大使 内连接.外连接 你真的会玩SQL吗?三范式.数据完整性 你真的会玩SQL吗?查询指定节点及其所有父节 ...

  6. Java实现时间动态显示方法汇总

    这篇文章主要介绍了Java实现时间动态显示方法汇总,很实用的功能,需要的朋友可以参考下 本文所述实例可以实现Java在界面上动态的显示时间.具体实现方法汇总如下: 1.方法一 用TimerTask: ...

  7. C#读写文件的方法汇总_C#教程_脚本之家

    C#读写文件的方法汇总_C#教程_脚本之家 http://www.jb51.net/article/34936.htm

  8. UITextView实现placeHolder方法汇总

    UITextField中有一个placeholder属性,可以设置UITextField的占位文字,起到提示用户的作用.可是UITextView就没那么幸运了,apple没有给UITextView提供 ...

  9. Java中hashCode()方法以及HashMap()中hash()方法

    Java的Object类中有一个hashCode()方法: public final native Class<?> getClass(); public native int hashC ...

  10. 将编码从GB2312转成UTF-8的方法汇总(从前台、程序、数据库)

    这篇文章主要介绍了将编码从GB2312转成UTF-8的方法汇总(从前台.程序.数据库),需要的朋友可以参考下 一个网站如果需要国际化,就需要将编码从GB2312转成UTF-8,其中有很多的问题需要注意 ...

随机推荐

  1. 洛谷P1047校门外的树题解

    题目 此题是一个模拟题,但需要注意的一点就是它的树是从数轴的0开始,所以我们也要从0开始,这样才能实现代码. 代码: #include<iostream> using namespace ...

  2. Heron and His Triangle HDU - 6222(pell 大数)

    ---恢复内容开始--- Heron and His Triangle Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 262144/2 ...

  3. jupyter更改存储路径

    实习了两个月爬虫,第一个月学到了不少东西,尤其是真实链接的抓取还有定时爬虫以及一些常规的反爬策略. 但是感觉第二个月的工作内容和预想的轨道渐渐脱离,所以选择了辞职,停下来重新看一下以后的路该怎么走,调 ...

  4. Tarjan求有向图强连通详解

    Tarjan求有向图强连通详解 注*该文章为转发,原文出处已经不得而知 :first-child { margin-top: 0; } blockquote > :last-child { ma ...

  5. Centos7之Gcc安装

    1下载Gcc包进行安装https://gcc.gnu.org 下载下来的是一个包文件,但是要进行一系列的编译安装,听麻烦的. 不如直接使用这个yum来从网络上进行安装. 2 yumyum instal ...

  6. [CQOI2017]小Q的表格(数论+分块)

    题目描述 小Q是个程序员. 作为一个年轻的程序员,小Q总是被老C欺负,老C经常把一些麻烦的任务交给小Q来处理.每当小Q不知道如何解决时,就只好向你求助. 为了完成任务,小Q需要列一个表格,表格有无穷多 ...

  7. [SDOI2010]大陆争霸

    幻想历8012年5月12日深夜,斯普林·布拉泽降下神谕:“Trust me, earn eternal life.”克里斯军团士气大增.作为克里斯军团的主帅,你决定利用这一机会发动奇袭,一举击败杰森国 ...

  8. 随机总数字里面选取随机数字进行随机排序案例(JAVA实现)

    随机总数字里面选取随机数字进行随机排序案例,案例如下: 代码code: package com.sec; import java.util.Arrays; import java.util.Scann ...

  9. POJ--3190 Stall Reservations(贪心排序)

    这里 3190 Stall Reservations 按照吃草时间排序 之后我们用 优先队列维护一个结束时间 每次比较堆顶 看是否满足 满足更新后放到里面不满足就在后面添加 #include<c ...

  10. J2EE--常见面试题总结 -- ( 一)

    StringBuilder和StringBuffer的区别: String       字符串常量   不可变  使用字符串拼接时是不同的2个空间 StringBuffer  字符串变量   可变   ...