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
分享到:
相关推荐
改编自 TextMate 使用的方法,该库提供了一个命令ruby-hash-syntax-toggle ,它尝试在 1.8 和 1.9 哈希样式之间自动转换选定的 ruby 代码区域。 安装 如果您选择不使用方便的包之一,则需要将包含ruby-hash-...
Ruby学习笔记 01 类的属性与方法 02 访问控制 03 Container(Array/Hash) 04 Iterator 05 简单数据类型 06 范围 07 方法 08 条件控制 09 异常处理
### Ruby中关于Hash的基本使用方法 #### 一、哈希的概念 哈希(Hash)是一种存储键值对的数据结构,在Ruby中,哈希允许我们通过键(Key)来访问值(Value)。与数组不同,数组的索引是整数型的,而哈希的键可以是...
本文将深入探讨Ruby中Hash的基本操作方法。 首先,理解Hash的基本概念至关重要。Hash是通过一个特定的函数,即哈希函数(hash function),将键映射到一个存储位置,以此实现快速查找。哈希函数通常是一个将任意...
这份"Ruby学习资料chm"集合了关于Ruby的基础学习材料,对于初学者或是希望深入理解Ruby的人来说是一份宝贵的资源。 Ruby的核心特性包括: 1. 面向对象:在Ruby中,一切都是对象,包括基本的数据类型如整数、字符串...
1.创建哈希:就像创建数组一样,我们可以通过Hash类来创建一个Hash实例: h1 = Hash.new #默认值为nil h2 = Hash.new(“This is my first hash instance”) #默认值为” This is my first hash instance”: 上面两...
在Ruby的方法中,如果方法名末尾带有感叹号(!),表示该方法会改变原有对象的值,相反,如果不带有感叹号,则会创建一个新的对象进行返回。例如,数组的sort方法不会改变原数组,而是返回一个新的排序后的数组;而...
Ruby支持五种基本的数据类型:符号(Symbol)、字符串(String)、数字(Numeric)、数组(Array)和哈希(Hash)。变量分为四种:局部变量(以小写字母或下划线开头)、实例变量(以`@`开头)、类变量(以`@@`开头...
这个笔记里包含了ruby的整型,字符串,浮点数,布尔等基础数据类型,还有数组,哈希hash的用法, 类的定义,函数方法,以及对象定义,其他高级用法解释,除了笔记记录的语法糖之外,还包含了一些解释性的代码,帮助...
4. **人类可读的哈希散列**:`to_human_hash_key`方法将哈希键转换为更易读的形式,比如将`"my_key"`转换为`"我的键"`,增强了代码的可读性。 5. **字符串的驼峰式和下划线式转换**:`camelize`和`underscore`方法...
Ruby Hash类扩展。 安装 gem install ds_hash 通过实例学习 哈希。 deep_key? hash = { :a => { :b => 'b' } } hash . deep_key? :a , :b # return true hash . deep_key? :a , :x # return false 哈希。 deep_...
这部分通常是对Ruby内置类库、方法、语法的详细参考,涵盖了标准库的所有模块和类,比如Array、Hash、String等。它提供了每个方法的用法、参数和返回值,是开发者在编写代码时查找特定功能或方法的重要资源。 3. *...
这个 Ruby gem 向 Nokogiri XML 节点添加了一个to_hash方法,允许我们将任意 XML 节点转换为 Ruby 哈希,并且还可以将它们序列化为 JSON。 这个 gem 还可以获取属性、处理指令和文档类型声明。 由此产生的哈希是...
- **动态性**:Ruby支持运行时修改代码结构,允许开发者在程序运行过程中改变类和方法的行为。 - **元编程能力**:Ruby提供了一种称为元编程的技术,使得程序可以自我修改和自我扩展。 ### 二、Ruby编程基础 #### ...
《ruby23-language.chm》文档深入讲解了Ruby语言的特性,如动态性、元编程、闭包和块、方法定义与调用、变量作用域等。Ruby允许在运行时修改代码,这使得元编程成为其强大之处。理解如何使用`eval`、`class_eval`和`...
Ruby还包含了一些其他重要的实用函数,如Array和Hash的内置方法。Array类提供了如`map`, `each`, `select`等方法,用于迭代和操作数组元素。Hash类允许键值对存储,其方法如`fetch`, `merge`, `keys`, `values`等能...
此外,Ruby还有数组(Array)和哈希(Hash)等复合数据类型。 2. **控制结构**:Ruby中的控制结构包括条件语句(如if/else,case/when)、循环(如for,while,until,each)以及流程控制语句(如break, next, ...
Ruby 学习笔记 1、简介 定义:一种简单快捷的面向对象脚本语言 开发者:松本行弘 开发时间:1995年 设计目的:A PROGRAMMER'S BEST FRIEND【程序员的最佳朋友】 文件扩展名:rb 2、语言特性 真正的面向对象编程语言 ...