ruby 標(biāo)準(zhǔn)類型總結(jié)
- Ruby支持整數(shù)和浮點(diǎn)數(shù),整數(shù)可以是任意長度
- 一定范圍內(nèi)的整數(shù)以二進(jìn)制存放,它們屬于fixnum類型,當(dāng)超出這個范圍時則自動轉(zhuǎn)換為bignum類型
- 表達(dá)方式:符號+一串字符,數(shù)字串中的下劃線會被忽略,(前綴包括:0表示八進(jìn)制, 0x表示十六進(jìn)制, 0b表示二進(jìn)制)123_456_789_123_345_789 # Bignum
0xaabb # 十六進(jìn)制 - 也可以通過在前面加上問號來得到ASCII碼字符對應(yīng)的整數(shù)值和轉(zhuǎn)義序列的值
?a # 普通字符
?\n # 換行符 (0x0a)
?\C-a # CTRL+a (0x01)
?\M-a # ALT+a
?\M-\C-a # CTRL+ALT+a
?\C-? # 刪除鍵 - 一個帶小數(shù)點(diǎn)的數(shù)字字面值被轉(zhuǎn)換成Float對象
- 所有的數(shù)字都是對象,不存在相應(yīng)的函數(shù)而是方法
exp:
數(shù)字的絕對值是aNumber.abs而不是abs(aNumber) - 整數(shù)有用的迭代器
3.times { print "X " } => X X X 1.upto(5) { |i| print i, " " } =>1 2 3 4 5 99.downto(95) { |i| print i, " " }=>99 98 97 96 95 50.step(80, 5) { |i| print i, " " }=>50 55 60 65 70 75 80
- Ruby的字符串是8位字節(jié)的簡單序列,字符串是String類的對象
- 注意轉(zhuǎn)換機(jī)制(注意單引號與雙引號的區(qū)別),如:
單引號中兩個相連的反斜線被替換成一個反斜線,,一個反斜線后跟一個單引號被替換成一個單引號
'escape using "\\"' >> 轉(zhuǎn)義為"\" 'That\'s right' >> That's right
- 雙引號支持多義的轉(zhuǎn)義
"\n"
#{expr}序列來替代任何的Ruby表達(dá)式的值 ,(全局變量、類變量或者實(shí)例變量,那么可以省略大括號)
"Seconds/day: #{24*60*60}" >> Seconds/day: 86400 "#{'Ho! '*3}Merry Christmas" >> Ho! Ho! Ho! Merry Christmas "This is line #$." >> This is line 3 - here document來創(chuàng)建一個字符串,end_of_string 為結(jié)束符號
aString = <<END_OF_STRING The body of the string is the input lines up to one ending with the same text that followed the '<<' END_OF_STRING - %q和%Q分別把字符串分隔成單引號和雙引號字符串(即%q與%Q后面的符號具有',"的功能)
%q/general single-quoted string/ >> general single-quoted string - String 常用功能
String#split:把行分解成字段
String#chomp:去掉換行符
String#squeeze:剪除被重復(fù)輸入的字符
String#scan:以指定想讓塊匹配的模式
exp:
/jazz/j00132.mp3 | 3:45 | Fats Waller | Ain't Misbehavin'
/jazz/j00319.mp3 | 2:58 | Louis Armstrong | Wonderful World
#文件格式如上,要進(jìn)行分解
songs = SongList.new
songFile.each do |line|
file, length, name, title = line.chomp.split(/\s*\|\s*/)#先chomp,后再分解,/\s*表示任字符
name.squeeze!(" ")#替換空格
mins, secs = length.scan(/\d+/)#這里用scan匹配模式
songs.append Song.new(title, name, mins.to_i*60+secs.to_i)
end
- 區(qū)間存在于任何地方,如:1到12月。ruby用區(qū)間實(shí)現(xiàn)了3個不同的特性:序列,條件,間隔。
- "..":兩個點(diǎn)號創(chuàng)建一個閉區(qū)間,"...":而三個點(diǎn)號創(chuàng)建一個右開區(qū)間(即右邊界不取值)
exp:0..anArray.length-1 等同于 0...anArray.length - to_a 把區(qū)間轉(zhuǎn)換成列表
exp: ('bar'..'bat').to_a >> ["bar", "bas", "bat"] - 區(qū)間的共它的用法
digits = 0..9
digits.include?(5) >> true
digits.min >> 0
digits.max >> 9
digits.reject {|i| i < 5 } >> [5, 6, 7, 8, 9]
digits.each do |digit|
dial(digit)
end - ruby能把基于自己定義的對象的區(qū)間,要求:這個對象必須能夠響應(yīng)succ方法來返回序列中的下一個對象,并且這個對象必須能夠使用<=>運(yùn)算符來被比較,即常規(guī)的比較運(yùn)算符,
- 間隔測試
puts (1..10).include?(3.14)=> ture
puts (1..10) === 3.14?。剑?ture
- 正則表達(dá)式是Regexp類型的對象,可以使用構(gòu)造器顯式地創(chuàng)建一個正則表達(dá)式,也可以使用字面值形式/pattern/和%r\pattern\來創(chuàng)建
- 用Regxp#match(aString)的形式或者匹配運(yùn)算符=~(正匹配)和!~(負(fù)匹配)來匹配字符串了。匹配運(yùn)算符在String和Regexp中都有定義,如果兩個操作數(shù)都是字符串,則右邊的那個要被轉(zhuǎn)換成正則表達(dá)式
exp:
a = "Fats Waller"
a =~ /a/ >> 1
a =~ /z/ >> nil
a =~ "ll" >> 7 - 上面返回的是匹配字符的位置,其它
$&接受被模式匹配到的字符串部分
$`接受匹配之前的字符串部分
$'接受之后的字符串。
exp:下面的方法后繼都會用到
def showRE(a,re)
if a =~ re
"#{$`}<<#{$&}>>#{$'}" #返回前、中、后
else
"no match"
end
end
- 模式,任何一個表達(dá)式都包含一個模式,它用來把正則表達(dá)式和字任串匹配
模式中除了., |, (, ), [, {, +, \, ^, $, *,和?以外的字任都匹配它自己
如果要匹配這些特殊的字符就需要加上反斜線做前綴,分析上面例字
/\s*\|\s*/,在\s與|之前都加了/做前綴。
showRE('kangaroo', /angar/) >> k<<angar>>oo
showRE('!@%&-_=+', /%&/) >> !@<<%&>>-_=+
showRE('yes | no', /\|/) >> yes <<|>> no
- \后跟一個字母或數(shù)字表示一個特定的結(jié)構(gòu)如\s表示字符等。
- 錨點(diǎn) 一個正則表達(dá)式總是返回找到模式的第一個匹配,如何改變?
模式^和$分別用來匹配行首和行尾
序列\(zhòng)A匹配字符串開始的位置,\z和\Z匹配字符串結(jié)尾的位置
\b和\B分別匹配字邊界和非字邊界
showRE("this is\nthe time", /^the/) >> this is\n<<the>> time
showRE("this is\nthe time", /is$/) >> this <<is>>\nthe time
showRE("this is\nthe time", /\Athis/) >> <<this>> is\nthe time
showRE('It costs $12.', /[aeiou]/) >> It c<<o>>sts $12.
a = 'Gamma [Design Patterns-page 123]'
showRE(a, /[]]/) >> Gamma [Design Patterns-page 123<<]>>
showRE(a, /[B-F]/) >> Gamma [<<D>>esign Patterns-page 123]
showRE(a, /[-]/) >> Gamma [Design Patterns<<->>page 123]
showRE(a, /[0-9]/) >> Gamma [Design Patterns-page <<1>>23]
序列 形如 [ ... ] 含義
\d [0-9] Digit character
\D [^0-9] Nondigit
\s [\s\t\r\n\f] Whitespace character 匹配一個單空白符
\S [^\s\t\r\n\f] Nonwhitespace character
\w [A-Za-z0-9_] Word character
\W [^A-Za-z0-9_] Nonword character
r * 匹配0個或多個r的出現(xiàn)
r + 匹配一個或多個r的出現(xiàn)
r ? 匹配0個或1個r的出現(xiàn)
r {m,n} 匹配最少m最多n個r的出現(xiàn)
r {m,} 匹配最少m個r的出現(xiàn)
重復(fù)結(jié)構(gòu)有高優(yōu)先權(quán):即它們僅和模式中的直接正則表達(dá)式前驅(qū)捆綁
/ab+/匹配一個"a"后跟一個活著多個"b",而不是"ab"的序列
/a*/會匹配任何字符串:0個或者多個"a"的任意字符串。
exp:
a = "The moon is made of cheese"
showRE(a, /\w+/) >> <<The>> moon is made of cheese
showRE(a, /\s.*\s/) >> The<< moon is made of >>cheese
showRE(a, /\s.*?\s/) >> The<< moon >>is made of cheese
showRE(a, /[aeiou]{2,99}/) >> The m<<oo>>n is made of cheese
showRE(a, /mo?o/) >> The <<moo>>n is made of cheese
"|"既匹配它前面的正則表達(dá)式或者匹配后面的
a = "red ball blue sky"
showRE(a, /d|e/) >> r<<e>>d ball blue sky
showRE(a, /al|lu/) >> red b<<al>>l blue sky
showRE(a, /red ball|angry sky/) >> <<red ball>> blue sky
圓括號把正則表達(dá)式分組,組中的內(nèi)容被當(dāng)作一個單獨(dú)的正則表達(dá)式
showRE('banana', /(an)+/) >> b<<anan>>a
# 匹配重復(fù)的字母
showRE('He said "Hello"', /(\w)\1/) >> He said "He<<ll>>o"
# 匹配重復(fù)的子字符串
showRE('Mississippi', /(\w+)\1/) >> M<<ississ>>ippi
你是否想過,大小寫替換。
方法String#sub和String#gsub都在字符串中搜索匹配第一個參數(shù)的部分,然后用第二個參數(shù)來替換它們。String#sub只替換一次,而String#gsub替換所有找到的匹配。都返回一個包含了替換的新的字符串的拷貝。進(jìn)化版本是String#sub!和 String#gsub!
a = "the quick brown fox"
a.sub(/[aeiou]/, '*') >> "th* quick brown fox"
a.gsub(/[aeiou]/, '*') >> "th* q**ck br*wn f*x"
a.sub(/\s\S+/, '') >> "the brown fox"
a.gsub(/\s\S+/, '') >> "the"
第二個參數(shù)可以是代碼塊
a = "the quick brown fox"
a.sub (/^./) { $&.upcase } >> "The quick brown fox"
a.gsub(/[aeiou]/) { $&.upcase } >> "thE qUIck brOwn fOx"
\& 后面的匹配
\+ 后面的匹配組
\` 匹配前面的字符串
\' 匹配后面的字符串
\\ 反斜線的字面值
正則表達(dá)式的字面值創(chuàng)建Regexp類
re = /cat/
re.type >> Regexp
方法Regexp#match從字符串中匹配一個正則表達(dá)式,如果不成功,方法返回nil,如果成功,返回MatchData類的一個實(shí)例
exp:
e = /(\d+):(\d+)/ # match a time hh:mm
md = re.match("Time: 12:34am")
md.type >> MatchData
md[0] # == $& >> "12:34"
md[1] # == $1 >> "12"
md[2] # == $2 >> "34"
md.pre_match # == $` >> "Time: "
md.post_match # == $' >> "am"
相關(guān)文章
Ruby on rails安裝后去掉DL is deprecated,please use Fiddle警告信息的方法【
這篇文章主要介紹了Ruby on rails安裝后去掉DL is deprecated,please use Fiddle警告信息的方法,通過針對Ruby on rails安裝文件中的警告部分源碼進(jìn)行注釋來達(dá)到消除警告的目的,需要的朋友可以參考下2017-02-02Ruby和Shell腳本實(shí)現(xiàn)判斷成績及格功能
這篇文章主要介紹了Ruby和Shell腳本實(shí)現(xiàn)判斷成績及格功能,使用Ruby實(shí)現(xiàn)這個功能非常簡潔優(yōu)雅,而Shell的實(shí)現(xiàn)就比較傳統(tǒng)了,需要的朋友可以參考下2015-01-01借助RubyGnome2庫進(jìn)行GTK下的Ruby GUI編程的基本方法
這篇文章主要介紹了借助RubyGnome2庫進(jìn)行GTK下的Ruby GUI編程的基本方法,介紹了基本的UI和事件響應(yīng)的相關(guān)實(shí)現(xiàn),需要的朋友可以參考下2015-12-12