Chinaunix首页 | 论坛 | 博客
  • 博客访问: 99023
  • 博文数量: 11
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 213
  • 用 户 组: 普通用户
  • 注册时间: 2013-08-23 18:34
文章分类

全部博文(11)

文章存档

2013年(11)

我的朋友

分类: Python/Ruby

2013-09-24 18:18:15

散列表

数组是对象的集合,散列表也是。然而,散列表有不同的存储格式,以及在集合中定义每个对象的不同方法。散列

表中的对象不在列表中给定位置,而是给定一个指定对象的键(key)。散列表更像字典,而不像列表,因为它没

有确定的顺序,只有键和值之间的简单链接。下面是个基本的散列表,其中有两个元素:
dictionary = {‘cat’=> 'feline animal',‘dog’=> 'canine animal'}

irb(main):029:0> dictionary = {'cat' => 'feline animal','dog' => 'canine animal'}
=> {"cat"=>"feline animal", "dog"=>"canine animal"}
irb(main):030:0> puts dictionary.size   \\ 检查一下其长度
2
=> nil
irb(main):031:0> puts dictionary['cat']  \\检索键‘cat’的值
feline animal
=> nil

irb(main):033:0>  dictionary['cat'] = 'female animal' \\更改键‘cat’的值
=> "female animal"
irb(main):034:0> puts dictionary['cat']    \\输出修改后的键‘cat’的值
female animal
=> nil

散列表的基本方法

对于数组,可以使用each方法实现在数组元素中迭代,对于散列表也可以进行此项操作,但由于散列表每个元素都

用键,因此迭代响应的顺序不固定:

irb(main):001:0> x = { "a" => 1, "b" => 2}
=> {"b"=>2, "a"=>1}
irb(main):002:0> x.each { |key, value| puts "#{key} equals #{value}" }
b equals 2
a equals 1
=> {"b"=>2, "a"=>1}

散列表的each迭代子方法是将两个参数传递给代码块:第一个是键,第二个是键所对应的值,上述的例子是把它们

赋给名为key和value的变量,并用字符串插写的方法,将其内容显示到屏幕上。

检索键

Ruby提供了keys方法,可以让用户很容易查看任何散列表的键:

irb(main):003:0> x = { "a" => 1, "b" => 2, "c" => 3}
=> {"c"=>3, "b"=>2, "a"=>1}
irb(main):004:0> puts x.keys.inspect
["c", "b", "a"]
=> nil

删除散列表中的元素

删除散列表元素很简单,使用delete方法即可,如:

irb(main):007:0> x = { "a" => 1, "b" => 2, "c" => 3}
=> {"c"=>3, "b"=>2, "a"=>1}
irb(main):008:0> x.delete("a")
=> 1
irb(main):009:0> puts x.inspect
{"c"=>3, "b"=>2}
=> nil

如果我们想删除符合条件的所有元素,那就使用delete_if 方法,如:

irb(main):011:0> x = { "a" => 120, "c" => 35, "d" => 49 }
=> {"d"=>49, "c"=>35, "a"=>120}
irb(main):012:0> x.delete_if {|key, value| value < 50}
=> {"a"=>120}
irb(main):013:0> puts x.inspect
{"a"=>120}
=> nil

阅读(2901) | 评论(0) | 转发(2) |
给主人留下些什么吧!~~