Ruby语言学习系列--基本的ruby语法 1. 基本的ruby语法 1.1 变量、常量和类型 1) 定义变量
变量类型 | 描述 | 示例 | 局部变量(或伪变量) | 以小写字母或下划线卡头 | var _var | 全局变量 | 以$开头 | $var | 类变量 | 类中定义,以@@开头 | @@var | 实例变量 | 对象中定义,以@开头 | @var | 常量 | 以大写字母开头 | Var | 2) 变量内插 在双引号内使用“#{变量名}”内插变量
a = 2 b = 3 puts "#{a} + #{b} = #{a+b}" #输入结果为:2 + 3 = 5 | 1.2 注释 1)单行注释:以#开头,如: #注释内容 2)多行注释:在=begin 和 =end 之间定义,如: =begin 注释内容 =end 1.3 循环和分支 1.3.1 条件语句
If 形式 | unless 形式 | a =1 if y==3 | a=1 unless y!=3 | x= if a > 0 then b else c end | x= unless a<=0 then a else b end | if x<5 then a =1 else a =2 end | unless x<5 then a =2 else a =1 end | 1.3.2 循环结构
#while循环 i= 0 while i< list.size do print “#list ” I += 1 end | #until循环 i= 0 until i == list.size do print “#list” i += 1 end | #for循环 for x in lisy do print “#{x}” end | #each循环 list.each do |x| print “#{x}” end | #loop循环 i = 0 n = list.size-1 loop do print “#{list}” i += 1 break id i > n end | #times循环 n = list.size n.times do |i| print “#{list}” end | #upto循环 n =list.size–1 0.upto(n) do |i| print “#{list}” end | #each_index循环 list.each_index do |x| print “#{list[x]}” end | 1.3.3 异常
begin x = Math.sqrt(y/z) rescue ArgumentError #匹配错误类型 puts "Error taking square root" rescue ZeroDivisionError #匹配错误类型 puts "Attempted division by zero" else puts "Other Error" ensure #这部分代码在最后一定会执行 end | 1.3.4 类
class Hello #类名必须以大写字母开头 @@myname = "John" #类变量 def initialize(name,phone) @name,@phone = name,phone #定义实例变量 end def hello #定义类方法 puts "#{@name}的电话是#{@phone}" end end f = Hello.new("Tom","13100000000") #创建类对象 f.hello #调用类方法,结果为:Tom的电话是13100000000 | 1.3.5 模块
方法 | 说明 | include ‘watir’ | 将模块的功能添加到当前空间中,不加载已加载的文件 | extend ‘watir’ | 将模块的函数添加到对象中 | load ‘watir’ | 读取文件,并将其插入到源文件的当前位置,以便从这个位置开始就可以使用其定义 | 1.3.6 case语句
case x when 1..10 #匹配数字 puts "First branch" when foobar() #批量方法返回的值 puts "Second branch" when /^hel.*/ #匹配正则表达式 puts "Third branch" else puts "Last branch" end | Ruby语言学习系列--String 类函数
函数名称 | 说明 | 示例 | * | 将字符串拷贝N次 | “ha”*4 >> “hahahaha” | + << concat | 连接字符串 | “yes” + “no” >> “yesno” "yes" << "no" >> “yesno” "yes".concat("no") | <=> | 比较字符串,返回值如下: 大于:-1 等于:0 小于:1 | "Ab" <=> "ab" >> -1 "ab" <=> "ab" >> 0 "ab" <=> "Ab" >> 1 | == 或 === | 判断两个对象是否相等 | "1" == "1" >>true "1" == 1 >>flase | =~ | 匹配正则表达式 | "abc123abc" =~ /"d/ >> 3 | [ ] 或 slice | 返回字符串的某一范围内的值 | “abc”[0,2] >> “ab” "hello"[/llo/] >> “llo” “abc” slice [0,2] >> “ab” | [ ]= | 替换字符串的某一范围内的值 | a = “hello word” a[1,2]= “OO” puts a >>” hOOlo word” | capitalize capitalize! | 把字符串的首字母大写,其他字母小写 | "hi,Ruby".capitalize >> “Hi,ruby” | chomp chomp! | 删除字符串后的空白字符 | "string"r"n".chomp >> ” string” | chop | 删除最后一个字符 | "string".chop >> “strin” | count | 返回该字符串中含的字符个数 | a = "hello world" a.count "lo" >> 5 (l出现 3次,o出现 2次) | delete delete! | 删除字符 | "hello".delete "l","lo" » "heo" "hello".delete "lo" » "he" | downcase downcase! | 将大写字母改写为小写 | "hEllO".downcase » "hello" | upcase upcase! | 将小写字母改写为大写 | "hEllO".upcase » "HELLO" | swapcaseswapcase! | 将所有的大写字母改为小写字母, 小写字母改为大写字母。 | "Hello".swapcase » "hELLO" | each | 对字符串中的各行进行迭代操作 | "Hi"nRuby". each { |s| puts s} | each_byte | 对字符串中的各个字节进行迭代操作 | "Hi"nRuby". each_byte { |s| puts s} | each_line | 对字符串中的每一行进行迭代操作 | "Hi"nRuby". each_line { |s| puts s} | empty? | 判断字符串是否为空 | "hello".empty? » false "".empty? » true | gsub gsub! | 以replace来替换字符串中所有与pattern相匹配的部分 | "hello".gsub(/[aeiou]/, '*') » "h*ll*" | hash | 返回字符串的哈希值 | "h".hash >> 107 | include? | 若字符串中包含substr子字符串的话,就返回真 | "hello".include? "lo" » true "hello".include? "ol" » false | index | 按照从左到右的顺序搜索子字符串,并返回搜索到的子字符串的左侧位置. 若没有搜索到则返回nil | "hello".index('lo') » 3 "hello".index('a') » nil | length | 返回字符串的字节数 | "hello".length >> 5 | replace | 替换字符串的内容 | s = "hello" » "hello" s.replace "world" » "world" | sub 或 sub! | 用replace来替换首次匹配pattern的部分。 | "hello".sub(/[aeiou]/, '*') » "h*llo" | reverse reverse! | 对字符串进行反转 | "stressed".reverse » "desserts" | scan | 使用正则表达式re反复对self进行匹配操作,并以数组的形式返回匹配成功的子字符串 | a = "cruel world" a.scan(/"w+/) » ["cruel", "world"] a.scan(/.../) » ["cru", "el ", "wor"] | split | 使用sep指定的pattern来分割字符串,并将分割结果存入数组 | "mellow yellow".split("ello") » ["m", "w y", "w"] | squeeze squeeze! | 压缩由str所含字符构成的重复字符串 | "yellow moon".squeeze » "yelow mon" " now is the".squeeze(" ") » " now is the" | strip strip! | 删除头部和尾部的所有空白字符。空白字符是指" "t"r"n"f"v"。 | " hello ".strip » "hello" ""tgoodbye"r"n".strip » "goodbye" | tr 或tr! | 若字符串中包含search字符串中的字符时,就将其替换为replace字符串中相应的字符 | hello".tr('aeiou', '*') » "h*ll*" "hello".tr('^aeiou', '*') » "*e**o" | tr_s 或tr_s! | 若字符串中包含search字符串中的字符时,就将其替换为replace字符串中相应的字符。同时,若替换部分中出现重复字符串时,就将其压缩为1个字符 | "hello".tr_s('l', 'r') » "hero" "hello".tr_s('el', '*') » "h*o" "hello".tr_s('el', 'hx') » "hhxo" | upto | 在从self到max的范围内,依次取出下一个字符串”后将其传给块,进行迭代操作 | "a1".upto("a3") {|s| puts s} » a1"na2"na3 | to_f | 将字符串转为浮点数 | "45.67 degrees".to_f » 45.67 | to_i | 将字符串转为整数 | "99 red balloons".to_i » 99 | to_s | 将字符串转为字符串 | | ruby学习系列--Hash类函数
函数名称 | 说明 | 示例 | == | 判断两个Hash是否相等 | h1 = {"a" => 1, "c" => 2} h2 = { "a" => 1, "c" => 2, 7 => 35 } h1 == h2 » false | [ ] | 返回指定键值对应的对象 | h = { "a" => 100, "b" => 200 } h["a"] » 100 h["c"] » nil | [ ]= | 向Hash添加记录 | h = { "a" => 100, "b" => 200 } h["a"] = 9 h["c"] = 4 h » {"a"=>9, "b"=>200, "c"=>4} | clear | 清空哈希表的内容. 返回self. | h = { "a" => 100, "b" => 200 } h.clear » {} | default | 返回哈希表的默认值 | h = { "a" => 100, "b" => 200 } h.default = "Go fish" h["a"] » 100 h["z"] » "Go fish" | delete | 从词典中删除和键值相符的记录 | h = { "a" => 100, "b" => 200 } h.delete("a") » 100 h.delete("z") » nil h.delete("z") { |el| "#{el} not found" } » "z not found" | delete_if | 通过过程块来删除特定键值的记录 | h = { "a" => 100, "b" => 200 } h.delete_if {|key, value| key >= "b" } » {"a"=>100} | each | Hash表的迭代操作,对表的每一个词对进行迭代操作 | h = { "a" => 100} h.each {|key, value| print key, " is ",value,""n"} » a is 100 | each_key | 对表的每一个键对进行迭代操作 | h = { "a" => 100, "b" => 200 } h.each_key {|key| print key } » ab | each_value | 针对value进行迭代操作 | h = { "a" => 100, "b" => 200 } h.each_value {|value| print value } » 100200 | empty? | 判断哈希表是否为空,空则返回true | {}.empty? » true | fetch | 如果能找到键值为key的hash值,则返回Hash值; 如果找不到,则返回默认值或指定值; 如果默认值和指定值都找不到,抛异常 | h = { "a" => 100, "b" => 200 } h.fetch("a") » 100 h.fetch("z", "go fish") » "go fish" h.fetch("k") »in `fetch': key not found (IndexError) | has_key? | 判断是否存在相符的key值 | h = { "a" => 100, "b" => 200 } h.has_key?("a") » true h.has_key?("z") » false | key? | h. key?("z") » false | include? | h.include?("b") » true | has_value? | 判断是否存在相符的value值 | h = { "a" => 100, "b" => 200 } h.has_value?(100) » true h.has_value?(999) » false | value? | h.value?(100) » true h.value?(999) » false | index | 返回给定值的键值,未找到返nil | h = { "a" => 100, "b" => 200 } h.index(200) » "b" h.index(999) » nil | indexes | 返回一系列给定的键值对应值组成的数组 | h = { "a" =>100, "b" =>200, "c" =>300 } h.indexes("a", "c") » [100,300] h.indexes("a","z") » [100,nil] | indices | h.indexes("a", "c") » [100,300] h.indexes("a", "z") » [100,nil] | invert | 将元素值和索引互换,返回变换后的哈希表. 注意:若原哈希表中若干不同的索引对应相同的元素值时,其变换结果将无法预测. | h = { "n" => 100,"m" => 100,"y" => 300} h.invert » {300=>"y",100=>"n"} | keys | 返回一个包含所有key的数组. | h = { "a" => 100, "b" => 200 } h.keys » ["a", "b"] | values | 返回一个包含所有vakue的数组. | h = { "a" => 100,"b" => 200,"c" => 300 } h.values » [100, 200, 300] | length | 返回词典中元素的个数 | h = { "d" =>100, "a"=> 200, "v" => 300} h.length » 3 h. size » 3 | size | rehash | 重新计算索引对应的哈希表值。 当与索引对应的哈希表值发生变化时,若不使用该方法来重新计算的话,将无法取出与索引对应的哈希表值。 | a = [ "a", "b" ] c = [ "c", "d" ] h = { a => 100, c => 300 } a[0] = "z" h.rehash » {["z", "b"]=>100, ["c", "d"]=>300} h[a] » 100 | replace | 以另外一张Hash表的内容来替换当前Hash表的内容 | h = {"a" =>100, "b" =>200 } h.replace({ "c" => 300, "d" => 400 }) » {"c"=>300, "d"=>400} | shift | 删除一个哈希表元素后 再以[key,value]数组的形式将其返回 | h = { 1 => "a", 2 => "b", 3 => "c" } h.shift » [1, "a"] h » {2=>"b", 3=>"c"} | sort | 对Hash进行排序 按键值从小到大排序 | h = { "b" => 30, "a" => 20, "c" => 10 } h.sort » [["a", 20], ["b", 30], ["c", 10]] h.sort {|a,b| a[1]<=>b[1]} » [["c", 10], ["a", 20], ["b", 30]] | to_a | 把Hash表转换为数组 数组按Hash表的键值从小到大排序 | h = {"c" =>300,"a" =>100,"d" =>400} » [["a", 100], ["c", 300], ["d", 400]] | to_s | 把Hash表转换为字符串 | h = { "c" => 300, "a" => 100, "d" => 400} h.to_s » "a100c300d400" | update | 用一张Hash表去更新另外张Hash表 | h1 = { "a" => 100, "b" => 200 } h2 = { "b" => 254, "c" => 300 } h1.update(h2) » {"a"=>100, "b"=>254, "c"=>300} | Ruby语言学习系列--Array类函数
函数名称 | 说明 | 示例 | & | 数组与,返回两数组的交集 | [1,2] & [2,3] » [2] | * | 复制数组n次 | [1,2]*2 » [1,2,1,2] | + | 返回两数组的并集,但不排除重复元素 | [1,2]+[2,3] » [1,2,2,3] | << | 追加元素,但不排除重复元素 | [1,2]<<[2,3] » [1,2,2,3] | | | 追加元素,但排除重复元素 | 1,2] | [2,3] » [1,2,3] | - | 返回第一个数组与第二个数组不同的元素 | [1,2]-[2,3] » [1] | <=> | 比较数组 | [1,2]<=>[2,3] »flase | == | 比较数组,若所有元素均相等时返回真 | [1,2]==[2,1] »flase | assoc | 从数组的每个元素中寻找指定对象 | [[1,2],[3,4]].assoc(2) » [1,2] | at | 找到数组的第N个元素 负数表示逆向查找 | ["a","b","c","d","e"].at(0) » "a" ["a","b","c","d","e"].at(-1) » "e" | clear | 删除数组中的所有元素 | ["a","b","c","d","e"]. clear | collect collect! | 用一个过程块对数组的每个元素进行处理 | ["a","b","c","d"].collect {|x| x + "!" } » ["a!", "b!", "c!", "d!"] | compact compact! | 删除值为nil的元素后生成新数组并返回它 | ["a",nil,"b",nil,"c",nil].compact » ["a", "b", "c"] | delete | 删除元素,如果元素重复,全部删除 | a = [ "a", "b", "b", "b", "c" ] a.delete("b") puts a » ["a","c"] | delete_at | 删除pos所指位置的元素并返回它。若pos超出数组范围则返回nil | a = %w( ant bat cat dog ) a.delete_at(2) » "cat" a » ["ant", "bat", "dog"] a.delete_at(99) » nil | delete_if | 根据条件删除 | a = [ "a", "b", "c" ] a.delete_if {|x| x >= "b" } » ["a"] | each | 对数组的每个元素按值进行迭代操作 | a = [ "a", "b", "c" ] a.each {|x| print x, " -- " } » "a -- b -- c --" | each_index | 对数组的每个元素按索引进行迭代操作 | a = [ "a", "b", "c" ] a.each_index {|x| print x, " -- " } » "0 -- 1 -- 2 --" | empty? | 判断数组是否为空,为空则返回真 | [].empty? » true | eql! | 比较两数组是否相等 | ["a","b","c"].eql?(["a","b","c"]) » true | fill | 填充数组 | ["a","b","c","d"].fill("x") » ["x","x","x","x"] ["a","b","c","d"].fill("z", 2, 2) » ["x", "x", "z", "z"] | first | 返回数组的首元素。若没有首元素则返回nil | [ "q", "r", "s", "t" ].first » "q" | last | 返回数组末尾的元素。若数组为空时,返回nil | ["w","x","y","z"].last » "z" | include? | 判断数组中是否包含元素 | a = [ "a", "b", "c" ] a.include?("b") » true a.include?("z") » false | index | 返回数组中第一个==val的元素的位置 | a = [ "a", "b", "c" ] a.index("b") » 1 a.index("z") » nil | indexes | 以数组形式返回其索引值与各参数值相等的元素 | a = [ "a", "b", "c", "d", "e", "f", "g" ] a.indexes(0, 2, 4) » ["a", "c", "e"] a.indexes( 2, 4, 12) » [ "c", "e", nil] | insert | 在索引为nth的元素前面插入第2参数以后的值 | ary = %w(foo bar baz) ary.insert 2,'a','b' p ary » ["foo", "bar", "a", "b", "baz"] | join | 将数组元素按一定的分隔符连接起来 | [ "a", "b", "c" ].join » "abc" [ "a", "b", "c" ].join("-") » "a-b-c" | length size | 返回数组长度。若数组为空则返回0 | [1,2,3].length » 3 [1,2,3].size » 3 | nitems | 返回非nil元素的个数 | [ 1, nil, 3, nil, 5 ].nitems » 3 | pop | 删除末尾元素并返回它。若数组为空则返回nil | a = [ "a", "m", "z" ] a.pop » "z" p a » ["a", "m"] | push | 添加新元素 | ["a","b"].push(['1','2']) » ["a", "b", ["1", "2"]] | rassoc | 遍历数组每个元素(元素必须是数组),匹配索引为1的值是否与查找的字符相等,返回第一个相等的元素 | a = [[15,1], [25,2], [35,2]] p a.rassoc(2) » [25, 2] | replace | 替换数组元素 | a = ["a","b"] a.replace(["x","y","z"]) p a »["x", "y", "z"] | reverse reverse! | 将所有元素以逆序重新排列生成新数组并返回它 | ["a","b","c" ].reverse » ["c", "b", "a"] | rindex | 返回最后一个值相等的元素的索引值 | a = [ "a","b","b","b","c"] a.rindex("b") » 3 | shift | 删除数组的首元素并返回它。剩余元素依次提前。若数组为空返回nil。 | args = ["-m","-q","filename"] args.shift » "-m" args » ["-q", "filename"] | sort sort! | 从小到大排序 | a = [ "d", "a", "e", "c", "b" ] a.sort » ["a", "b", "c", "d", "e"] | uniq uniq! | 删除数组中的重复元素后生成新数组并返回它 | a = [ "a", "a", "b", "b", "c" ] a.uniq » ["a", "b", "c"] | unshift | 在数组第一个元素前添加元素 | a = [ "b", "c", "d" ] a.unshift("a") » ["a", "b", "c", "d"] | to_s | 将数组的所有元素连接成字符串 | ["a","e","i","o"].to_s » "aeio" | Ruby语言学习系列--Numeric类函数
函数名称 | 说明 | 示例 | chr | 返回数字的ACSII码 | 65.chr >> “A” | downto | 接收一个block,从大到小循环执行 | 5.downto(2) { |i| puts i} >> 5 4 3 2 | upto | 接收一个block,从小到大循环执行 | 2.upto(5) { |i| puts i} >> 2 3 4 5 | next或succ | 返回下一个数 | 1.next >> 2 1.succ >>2 | step | 以固定步长循环执行 | 1.step(10,2) { |i| puts i} >> 1 2 3 5 7 | times | 循环执行n次 | 5.times { |i| puts i} >> 1 2 3 4 5 | Ruby语言学习系列--Float类函数
函数名称 | 说明 | 示例 | ceil | 返回比float大的最小整数 | (2.98).ceil >> 3 | floor | 返回比float小的最大整数 | (2.98). floor >> 2 | round | 四舍五入到一个整数 | (2.98). round >> 3 | to_i | 返回float截掉小数点后的整数 | (2.98).to_i >> 2
| |