- 921. Minimum Add to Make Parentheses Valid 使括号有效的最少添加
- 915. Partition Array into Disjoint Intervals 分割数组
- 932. Beautiful Array 漂亮数组
- 940. Distinct Subsequences II 不同的子序列 II
Ruby 的 哈希表(Hash)是类似 "key" => "value" 这样的键值对集合
哈希类似于一个数组,只不过它的索引不局限于使用数字。
Hash 的键可以是任何对象。
Hash 虽然和数组类似,但却有一个很重要的区别:
Hash 的元素没有特定的顺序
创建哈希表(Hash) 有很多种方式
myhash = Hash.new
默认传递的参数是 nil
myhash = Hash.new( "month" )
或
myhash = Hash.new "month"
访问带有默认值的哈希中的任意键时,如果键或值不存在,哈希表将返回默认值
# !/usr/bin/ruby -w
# -*- encoding:utf-8 -*-
# filename: main.rb
# author: DDKK.COM 弟弟快看,程序员编程资料站(www.ddkk.com)
# Copyright © 2015-2065 www.ddkk.com. All rights reserved.
myhash = Hash.new( "ddkk.cn" )
puts "#{myhash[0]}"
puts "#{myhash[72]}"
运行范例 »
运行以上范例,输出结果如下:
$ ruby main.rb
ddkk.cn
ddkk.cn
# !/usr/bin/ruby -w
# -*- encoding:utf-8 -*-
# filename: main.rb
# author: DDKK.COM 弟弟快看,程序员编程资料站(www.ddkk.com)
# Copyright © 2015-2065 www.ddkk.com. All rights reserved.
myhash = Hash["baidu" => "baidu.com", "ali" => "taobao.com"]
puts "#{myhash['baidu']}"
puts "#{myhash['ali']}"
puts "#{myhash['tencent']}"
尝试一下 »
运行以上范例,输出结果如下
$ ruby main.rb
baidu.com
taobao.com
Ruby 语言允许使用任何的 Ruby 对象作为键或值,甚至可以使用数组
[1,"jan"] => "January"
调用 哈希表(Hash) 的方法需要先实例化一个 Hash 对象
创建Hash 对象实例的方法有四种方式:
Hash[[key =>|, value]* ]
Hash.new
Hash.new(obj)
Hash.new { |**hash, key| block }
它们都会返回一个使用给定对象进行填充的新的哈希。
创建了哈希表对象之后,就可以调用任意可用的方法
# !/usr/bin/ruby -w
# -*- encoding:utf-8 -*-
# filename: main.rb
# author: DDKK.COM 弟弟快看,程序员编程资料站(www.ddkk.com)
# Copyright © 2015-2065 www.ddkk.com. All rights reserved.
$, = ", "
months = Hash.new( "month" )
months = {"1" => "January", "2" => "February"}
keys = months.keys
puts "#{keys}"
运行范例 »
运行以上范例,输出结果如下
$ ruby main.rb
["1", "2"]
hash 是一个 Hash 对象
序号 | 方法 & 描述 |
---|---|
1 | hash == other_hash 检查两个哈希是否具有相同的键值对个数,键值对是否相互匹配,来判断两个哈希是否相等 |
2 | hash.[key] 使用键,从哈希引用值。如果未找到键,则返回默认值 |
3 | hash.[key]=value 把value给定的值与key给定的键进行关联 |
4 | hash.clear 从哈希中移除所有的键值对 |
5 | hash.default(key = nil) 返回 hash 的默认值,如果未通过 default= 进行设置,则返回 nil。(如果键在hash中不存在,则 [] 返回一个默认值。) |
6 | hash.default = obj 为 hash 设置默认值 |
7 | hash.default_proc 如果 hash 通过块来创建,则返回块 |
8 | hash.delete(key) array.delete(key) { |key| block } 通过key从hash中删除键值对。如果使用了块 且未找到匹配的键值对,则返回块的结果。把它与delete_if进行比较 |
9 | hash.delete_if { |key,value| block } block 为 true 的每个块,从hash中删除键值对 |
10 | hash.each { |key,value| block } 遍历hash,为每个key调用一次 block,传递 key-value 作为一个二元素数组 |
11 | hash.each_key { |key| block } 遍历 hash,为每个key调用一次 block,传递key作为参数 |
12 | hash.each_key { |key_value_array| block } 遍历hash,为每个key调用一次 block,传递key和value作为参数 |
13 | **hash.each_value |
14 | hash.empty? 检查 hash 是否为空(不包含键值对),返回true或false |
15 | hash.fetch(key [, default] ) hash.fetch(key) { | key | block } 通过给定的key从hash返回值。如果未找到key,且未提供其他参数,则抛出IndexError异常;如果给出了default,则返回default;如果指定了可选的 block,则返回 block 的结果 |
16 | hash.has_key?(key) hash.include?(key) hash.key?(key) hash.member?(key) 检查给定的key是否存在于哈希中,返回true或false |
17 | hash.has_value?(value) 检查哈希是否包含给定的value |
18 | hash.index(value) 为给定的value返回哈希中的key,如果未找到匹配值则返回nil |
19 | hash.indexes(keys) 返回一个新的数组,由给定的键的值组成。找不到的键将插入默认值。该方法已被废弃,请使用 select |
20 | hash.indices(keys) 返回一个新的数组,由给定的键的值组成。找不到的键将插入默认值。该方法已被废弃,请使用 select |
21 | hash.inspect 返回哈希的打印字符串版本 |
22 | hash.invert 创建一个新的hash,倒置hash中的keys和values。也就是说,在新的哈希中,hash中的键将变成值,值将变成键 |
23 | hash.keys 创建一个新的数组,带有hash中的键。/td> |
24 | hash.length 以整数形式返回hash的大小或长度 |
25 | hash.merge(other_hash) hash.merge(other_hash) { |key, oldval, newval| block } 返回一个新的哈希,包含 hash 和 other_hash 的内容,重写 hash 中与 other_hash 带有重复键的键值对 |
26 | hash.merge!(other_hash) hash.merge!(other_hash) { |key, oldval, newval| block } 与 merge 相同,但实际上 hash 发生了变化 |
27 | hash.rehash 基于每个key的当前值重新建立hash。如果插入后值发生了改变,该方法会重新索引hash |
28 | hash.reject { |key, value| block } 类似 delete_if, 但作用在一个拷贝的哈希上。相等于 hsh.dup.delete_if |
29 | hash.reject! { |key, value| block } 相等于 delete_if, 但是如果没有修改,返回 nil |
30 | hash.replace(other_hash) 把hash的内容替换为other_hash的内容 |
31 | hash.select { |key, value| block } 返回一个新的数组,由block返回true的hash中的键值对组成 |
32 | hash.shift 从hash中移除一个键值对,并把该键值对作为二元素数组返回 |
33 | hash.size 以整数形式返回 hash 的 size 或 length |
34 | hash.sort 把 hash 转换为一个包含键值对数组的二维数组,然后进行排序 |
35 | hash.store(key, value) 存储 hash 中的一个键值对 |
36 | hash.to_a 从 hash 中创建一个二维数组。每个键值对转换为一个数组,所有这些数组都存储在一个数组中 |
37 | hash.to_hash 返回 hash(self) |
38 | hash.to_s 把hash转换为一个数组,然后把该数组转换为一个字符串 |
39 | hash.update(other_hash) hash.update(other_hash) {|key, oldval, newval| block} 返回一个新的哈希,包含hash和other_hash的内容,重写hash中与other_hash带有重复键的键值对 |
40 | hash.value?(value) 检查hash是否包含给定的value |
41 | hash.values 返回一个新的数组,包含hash的所有值 |
42 | hash.values_at(obj, ...) 返回一个新的数组,包含hash中与给定的键相关的值 |
我有一台 MySQL 服务器和一台 PostgreSQL 服务器。 需要从多个表中复制或重新插入一组数据 MySQL 流式传输/同步到 PostgreSQL 表。 这种复制可以基于时间(Sync)或事
如果两个表的 id 彼此相等,我尝试从一个表中获取数据。这是我使用的代码: SELECT id_to , email_to , name_to , status_to
我有一个 Excel 工作表。顶行对应于列名称,而连续的行每行代表一个条目。 如何将此 Excel 工作表转换为 SQL 表? 我使用的是 SQL Server 2005。 最佳答案 这取决于您使用哪
我想合并两个 Django 模型并创建一个模型。让我们假设我有第一个表表 A,其中包含一些列和数据。 Table A -------------- col1 col2 col3 col
我有两个表:table1,table2,如下所示 table1: id name 1 tamil 2 english 3 maths 4 science table2: p
关闭。此题需要details or clarity 。目前不接受答案。 想要改进这个问题吗?通过 editing this post 添加详细信息并澄清问题. 已关闭 1 年前。 Improve th
下面两个语句有什么区别? newTable = orginalTable 或 newTable.data(originalTable) 我怀疑 .data() 方法具有性能优势,因为它在标准 AX 中
我有一个表,我没有在其中显式定义主键,它并不是真正需要的功能......但是一位同事建议我添加一个列作为唯一主键以随着数据库的增长提高性能...... 谁能解释一下这是如何提高性能的? 没有使用索引(
如何将表“产品”中的产品记录与其不同表“图像”中的图像相关联? 我正在对产品 ID 使用自动增量。 我觉得不可能进行关联,因为产品 ID 是自动递增的,因此在插入期间不可用! 如何插入新产品,获取产品
我有一个 sql 表,其中包含关键字和出现次数,如下所示(尽管出现次数并不重要): ____________ dog | 3 | ____________ rat | 7 | ____
是否可以使用目标表中的LAST_INSERT_ID更新源表? INSERT INTO `target` SELECT `a`, `b` FROM `source` 目标表有一个自动增量键id,我想将其
我正在重建一个搜索查询,因为它在“我看到的”中变得多余,我想知道什么 (albums_artists, artists) ( ) does in join? is it for boosting pe
以下是我使用 mysqldump 备份数据库的开关: /usr/bin/mysqldump -u **** --password=**** --single-transaction --databas
我试图获取 MySQL 表中的所有行并将它们放入 HTML 表中: Exam ID Status Assigned Examiner
如何查询名为 photos 的表中的所有记录,并知道当前用户使用单个查询将哪些结果照片添加为书签? 这是我的表格: -- -- Table structure for table `photos` -
我的网站都在 InnoDB 表上运行,目前为止运行良好。现在我想知道在我的网站上实时发生了什么,所以我将每个页面浏览量(页面、引荐来源网址、IP、主机名等)存储在 InnoDB 表中。每秒大约有 10
我在想我会为 mysql 准备两个表。一个用于存储登录信息,另一个用于存储送货地址。这是传统方式还是所有内容都存储在一张表中? 对于两个表...有没有办法自动将表 A 的列复制到表 B,以便我可以引用
我不是程序员,我从这个表格中阅读了很多关于如何解决我的问题的内容,但我的搜索效果不好 我有两张 table 表 1:成员 id*| name | surname -------------------
我知道如何在 ASP.NET 中显示真实表,例如 public ActionResult Index() { var s = db.StaffInfoDBSet.ToList(); r
我正在尝试运行以下查询: "insert into visits set source = 'http://google.com' and country = 'en' and ref = '1234
我是一名优秀的程序员,十分优秀!