今天学习的是数组和Hash,数组在很多编程语言中都能常常用到。
数组:
数组是存储数据的一种容器,在Ruby中,数组中存储的数据可以是任何类型的数据;这和JAVA不同,在JAVA中,数组是存储同一类型数据的结构。
1. 在Ruby中如何定义数组呢?
使用[ ]来框住元素,而元素之间则使用","间隔。如下,
name = ["Windy", "Cindy", "Amee", "Tom"] name = [] #声明了一个空数组,未定义的数组 name = [1, "song", 3, "小林"]
2. 如何取得数组元素呢?
在Ruby通过 数组名[index] 来获取数组元素,这和JAVA是一样的。而且index序号是从0开始的。例如,在上面的例子中,想要取出"Windy"这个元素,则要使用name[0],而 p name[3] # -> "Tom"。
3. 如何将对象放入数组中呢?
可以直接通过给数组元素赋值
name = ["Alice", "John", "Bob", "Jessie"] name[1] = "Jack" p name #-> ["Alice", "Jack", "Bob", "Jessie"] name[4] = "Windy" p name #-> ["Alice", "Jack", "Bob", "Jessie", "Windy"]
4. 如何取得数组的大小?
使用size方法可以返回数组大小。例如,上面实例中第一次定义的数组name, p name.size # -> 4 在JAVA中,数组是有属性length来获取数组大小的。
5. 如何逐项处理数组中的内容?
可以使用数组的each方法来对数组中的内容逐项处理,语法如下:
=begin 语法: 数组。each { |变量| 要执行的动作 } =end name = [2, 5, ,6, 9] name.each{ |number| prints number+1, "\n" } # -> 3 # 6 # 7 # 10
这和JAVA中的for each循环类似。
HASH:
HASH是经常使用的容器之一,在Ruby中,其可以使用字符串等数据为key来存储对象,和JAVA中的Map容器很类似。
1. 如何定义HASH呢?
使用{ }将HASH对象都框住,而每个元素以key=>value的形式出现,而元素之间通过","间隔。
name_list = {"01" => "Windy", "02" => "Cindy", "03" => "Terry"}
2. 如何取得HASH中的元素呢?
使用 HASH名称[key值] 来获取HASH元素,例如,
p name_list["01"] # -> "Windy"
3. 如何将对象储存到HASH中?
和上面说到的数组类似,直接将值赋给HASH元素,例如: name_list["02"] = "Amy"
由于HASH没有固定的顺序,所以不能按照存储的顺序来取出数据,这和JAVA中的Hash Table很类似。
4. 如何逐项处理HASH内容
与数组类似,其也是通过它的each方法来逐项处理其元素
=begin 语法 HASH.each { |key变量,值变量| 想要执行的动作 } =end name_list.each{ |key, value| print key, " = ", value, "\n" } # -> "01" = "Windy" # "02" = "Cindy" # "03" = "Terry"
Ruby还有重定向(redirect)的功能,就是把执行结果文件再存储到另外的文件中,使用">文件名"来实现,例如,ruby name_list.rb > name_list.txt
正则表达式:
在其他编程语言中,也都有正则表达式。在Ruby中,使用如下语法:/样式/ =~ 想要匹配的字符串
如果匹配成功,则返回匹配成功的位置,位置是从0开始计算的;如果匹配不成功,则返回nil。若/样式/i,即多加了一个i,则匹配时就不区分大小写了。
p /Ruby/ =~ "Another Ruby Hacker" #-> 8 p /Another Ruby Hacker/ =~ "Ruby" #-> nil p /Ruby/ =~ "ruby" #-> nil p /Ruby/i =~ "ruby" #-> 0
样式也可以通过Regexp类的new方法来构造,例如,pattern = Regexp.new(参数)