一。给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
本文出自 http://blackanger.blog.51cto.com/140924/88709
分享到:
相关推荐
改编自 TextMate 使用的方法,该库提供了一个命令ruby-hash-syntax-toggle ,它尝试在 1.8 和 1.9 哈希样式之间自动转换选定的 ruby 代码区域。 安装 如果您选择不使用方便的包之一,则需要将包含ruby-hash-...
官方离线安装包,亲测可用
官方离线安装包,亲测可用
赠送jar包:shiro-crypto-hash-1.4.0.jar; 赠送原API文档:shiro-crypto-hash-1.4.0-javadoc.jar; 赠送源代码:shiro-crypto-hash-1.4.0-sources.jar; 赠送Maven依赖信息文件:shiro-crypto-hash-1.4.0.pom; ...
Jemter测试MQ的插件 JMeter-Rabbit-AMQP在github上17年便停止更新了,不支持rabbitmq的交换机类型“x-consistent-hash”,为此我更改了源码使其支持"x-consistent-hash
Ohm - Redis的Object-hash映射库
这个 Ruby gem 向 Nokogiri XML 节点添加了一个to_hash方法,允许我们将任意 XML 节点转换为 Ruby 哈希,并且还可以将它们序列化为 JSON。 这个 gem 还可以获取属性、处理指令和文档类型声明。 由此产生的哈希是...
赠送jar包:shiro-crypto-hash-1.4.0.jar; 赠送原API文档:shiro-crypto-hash-1.4.0-javadoc.jar; 赠送源代码:shiro-crypto-hash-1.4.0-sources.jar; 赠送Maven依赖信息文件:shiro-crypto-hash-1.4.0.pom; ...
Hash-Hash-Hash
内容描述:用于crypto中hash爆破的强大工具。 优势:相较于其他hash工具,具有更快的算力,使用方便简洁。 适用:适用于md5,sha256等典型hash加密方式,反推出所需的源码。
前端开源库-copy-webpack-plugin-hash复制Webpack插件哈希,使用Webpack复制文件和目录
无线安全破解专用WPA-PSK_Hash_Table_DVD下载地址汇总.
Go语言开发的基于DRH(Deep-Re-Hash)深度哈希分区算法的高性能Key-Value嵌入式数据库
表情翻译学习目标将数据从文件转换为可用的Ruby数据结构遍历哈希数据以查找特定值背景您的朋友JJ刚搬到日本,并且很喜欢。 但是,有时他会因为新朋友发给他的表情符号发短信而感到困惑,例如, \(◎o◎)/! 和((d[-...
从注册表导取Windows-hash方法-到-远程HASH注入.docx
pass-the-hash attack theory and implementation
前端项目-leaflet-hash,linkable location hashes for leaflet
高级密码学报告------Hash算法与RSA算法分析与研究 适合高级密码学期末作业。 随着信息化和数字化社会的发展,人们对信息安全和保密的重要性认识不断提高,而在信息安全中起着举足轻重作用的密码学也就成为信息安全...
安装与npm npm install webpack-plugin-hash-output --save-dev带纱yarn add webpack-plugin-hash-output --dev为什么? 还有其他的webpack插件可以在那里散列。 但是,当它们运行时,它们不会“看到”代码的最终...
关于hash攻击的国外最新技术,主要是针对域环境下的攻击手段,相信你懂得!