麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > Ruby > 正文

ruby 標(biāo)準(zhǔn)類型總結(jié)

2020-03-29 12:11:22
字體:
供稿:網(wǎng)友
一、數(shù)字
  1. Ruby支持整數(shù)和浮點(diǎn)數(shù),整數(shù)可以是任意長(zhǎng)度
  2. 一定范圍內(nèi)的整數(shù)以二進(jìn)制存放,它們屬于fixnum類型,當(dāng)超出這個(gè)范圍時(shí)則自動(dòng)轉(zhuǎn)換為bignum類型
  3. 表達(dá)方式:符號(hào)+一串字符,數(shù)字串中的下劃線會(huì)被忽略,(前綴包括:0表示八進(jìn)制, 0x表示十六進(jìn)制, 0b表示二進(jìn)制)123_456_789_123_345_789 # Bignum
    0xaabb # 十六進(jìn)制
  4. 也可以通過在前面加上問號(hào)來得到ASCII碼字符對(duì)應(yīng)的整數(shù)值和轉(zhuǎn)義序列的值
    ?a # 普通字符
    ?/n # 換行符 (0x0a)
    ?/C-a # CTRL+a (0x01)
    ?/M-a # ALT+a
    ?/M-/C-a # CTRL+ALT+a
    ?/C-? # 刪除鍵
  5. 一個(gè)帶小數(shù)點(diǎn)的數(shù)字字面值被轉(zhuǎn)換成Float對(duì)象
  6. 所有的數(shù)字都是對(duì)象,不存在相應(yīng)的函數(shù)而是方法
    exp:
    數(shù)字的絕對(duì)值是aNumber.abs而不是abs(aNumber)
  7. 整數(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
二、字符串
  1. Ruby的字符串是8位字節(jié)的簡(jiǎn)單序列,字符串是String類的對(duì)象
  2. 注意轉(zhuǎn)換機(jī)制(注意單引號(hào)與雙引號(hào)的區(qū)別),如:
    單引號(hào)中兩個(gè)相連的反斜線被替換成一個(gè)反斜線,,一個(gè)反斜線后跟一個(gè)單引號(hào)被替換成一個(gè)單引號(hào)
    'escape using "//"' >> 轉(zhuǎn)義為"/" 'That/'s right' >> That's right
  3. 雙引號(hào)支持多義的轉(zhuǎn)義
    "/n"

    #{expr}序列來替代任何的Ruby表達(dá)式的值 ,(全局變量、類變量或者實(shí)例變量,那么可以省略大括號(hào))
    "Seconds/day: #{24*60*60}" >> Seconds/day: 86400 "#{'Ho! '*3}Merry Christmas" >> Ho! Ho! Ho! Merry Christmas "This is line #$." >> This is line 3
  4. here document來創(chuàng)建一個(gè)字符串,end_of_string 為結(jié)束符號(hào)
    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
  5. %q和%Q分別把字符串分隔成單引號(hào)和雙引號(hào)字符串(即%q與%Q后面的符號(hào)具有',"的功能)
    %q/general single-quoted string/ >> general single-quoted string
  6. 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, target='_blank'>正則表達(dá)式
  1. 正則表達(dá)式是Regexp類型的對(duì)象,可以使用構(gòu)造器顯式地創(chuàng)建一個(gè)正則表達(dá)式,也可以使用字面值形式/pattern/和%r/pattern/來創(chuàng)建
  2. 用Regxp#match(aString)的形式或者匹配運(yùn)算符=~(正匹配)和!~(負(fù)匹配)來匹配字符串了。匹配運(yùn)算符在String和Regexp中都有定義,如果兩個(gè)操作數(shù)都是字符串,則右邊的那個(gè)要被轉(zhuǎn)換成正則表達(dá)式
    exp:
    a = "Fats Waller"
    a =~ /a/ >> 1
    a =~ /z/ >> nil
    a =~ "ll" >> 7
  3. 上面返回的是匹配字符的位置,其它
    $&接受被模式匹配到的字符串部分
    $`接受匹配之前的字符串部分
    $'接受之后的字符串。
    exp:下面的方法后繼都會(huì)用到

    def showRE(a,re)
    if a =~ re
    "#{$`}<<#{$&}>>#{$'}" #返回前、中、后
    else
    "no match"
    end
    end
  4. 模式,任何一個(gè)表達(dá)式都包含一個(gè)模式,它用來把正則表達(dá)式和字任串匹配
    模式中除了., |, (, ), [, {, +, /, ^, $, *,和?以外的字任都匹配它自己
    如果要匹配這些特殊的字符就需要加上反斜線做前綴,分析上面例字
    //s*/|/s*/,在/s與|之前都加了/做前綴。

    showRE('kangaroo', /angar/) >> k<<angar>>oo
    showRE('!@%&-_=+', /%&/) >> !@<<%&>>-_=+
    showRE('yes | no', //|/) >> yes <<|>> no
  5. /后跟一個(gè)字母或數(shù)字表示一個(gè)特定的結(jié)構(gòu)如/s表示字符等。
  6. 錨點(diǎn) 一個(gè)正則表達(dá)式總是返回找到模式的第一個(gè)匹配,如何改變?
    模式^和$分別用來匹配行首和行尾
    序列/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

 

五、字符類
  1. 這里的字符類不是面向?qū)ο蟮念悾槐硎具@些這字符屬于一個(gè)特殊的種類
  2. 字符類是用方括號(hào)擴(kuò)起來的字符的集合:[characters]匹配方括號(hào)中的所有單字符。[aeiou]匹配元音,[,.:'!?]匹配標(biāo)點(diǎn)符號(hào)等等
    showRE('It costs $12.', /[aeiou]/) >> It c<<o>>sts $12.
  3. 在方括號(hào)中的序列c1-c2表示在c1-c2之間也包括c1和c2的所有字符
    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]
  4. 緊跟在開括號(hào)([)后的是字符^,這表示這個(gè)字符類的否定:[^a-z]匹配任何不是小寫字母的字符。
  5. 字符類縮寫
    序列 形如 [ ... ] 含義
    /d [0-9] Digit character
    /D [^0-9] Nondigit
    /s [/s/t/r/n/f] Whitespace character 匹配一個(gè)單空白符
    /S [^/s/t/r/n/f] Nonwhitespace character
    /w [A-Za-z0-9_] Word character
    /W [^A-Za-z0-9_] Nonword character
  6. 重復(fù)
    r * 匹配0個(gè)或多個(gè)r的出現(xiàn)
    r + 匹配一個(gè)或多個(gè)r的出現(xiàn)
    r ? 匹配0個(gè)或1個(gè)r的出現(xiàn)
    r {m,n} 匹配最少m最多n個(gè)r的出現(xiàn)
    r {m,} 匹配最少m個(gè)r的出現(xiàn)

    重復(fù)結(jié)構(gòu)有高優(yōu)先權(quán):即它們僅和模式中的直接正則表達(dá)式前驅(qū)捆綁
    /ab+/匹配一個(gè)"a"后跟一個(gè)活著多個(gè)"b",而不是"ab"的序列
    /a*/會(huì)匹配任何字符串:0個(gè)或者多個(gè)"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
  7. 替換
    "|"既匹配它前面的正則表達(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
  8. 分組
    圓括號(hào)把正則表達(dá)式分組,組中的內(nèi)容被當(dāng)作一個(gè)單獨(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
  9. 基于模式的替換
    你是否想過,大小寫替換。
    方法String#sub和String#gsub都在字符串中搜索匹配第一個(gè)參數(shù)的部分,然后用第二個(gè)參數(shù)來替換它們。String#sub只替換一次,而String#gsub替換所有找到的匹配。都返回一個(gè)包含了替換的新的字符串的拷貝。進(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"
    第二個(gè)參數(shù)可以是代碼塊
    a = "the quick brown fox"
    a.sub (/^./) { $&.upcase } >> "The quick brown fox"
    a.gsub(/[aeiou]/) { $&.upcase } >> "thE qUIck brOwn fOx"
  10. 反斜線序列用在替換中
    /& 后面的匹配
    /+ 后面的匹配組
    /` 匹配前面的字符串
    /' 匹配后面的字符串
    // 反斜線的字面值
  11. 面向?qū)ο蟮恼齽t表達(dá)式
    正則表達(dá)式的字面值創(chuàng)建Regexp類
    re = /cat/
    re.type >> Regexp

    方法Regexp#match從字符串中匹配一個(gè)正則表達(dá)式,如果不成功,方法返回nil,如果成功,返回MatchData類的一個(gè)實(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"

上一篇:ruby 去掉文件里重復(fù)的行

下一篇:ruby on rails 代碼技巧

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
學(xué)習(xí)交流
熱門圖片

新聞熱點(diǎn)

疑難解答

圖片精選

網(wǎng)友關(guān)注

主站蜘蛛池模板: 精品一区二区在线观看 | 99亚洲 | 欧美成人午夜精品久久久 | 久久精品99北条麻妃 | 国产精品成人一区二区三区电影毛片 | 泰剧19禁啪啪无遮挡 | 免费国产人成网站 | 一级做人爱c黑人影片 | 干少妇av | 全黄裸片武则天一级第4季 偿还电影免费看 | 亚洲午夜视频 | 免费黄色成人 | 午夜视频国产 | 香蕉秀 | 日本高清在线免费 | 男男啪羞羞视频网站 | 国产网站黄 | 国产资源在线看 | 成人三级免费电影 | 三人弄娇妻高潮3p视频 | 色视频在线播放 | 亚洲卡通动漫在线观看 | 久久久三区 | 一色视频 | 黄视频网站免费在线观看 | 成人免费视频视频在线观看 免费 | 黄色大片免费网站 | 欧美一区二区三区中文字幕 | 色交视频 | 久久久成人精品视频 | 欧美日韩一区二区综合 | 巨乳毛片 | 一级毛片播放 | 91情侣偷在线精品国产 | 成人18在线 | 少妇一级淫片免费放正片 | 日韩视频―中文字幕 | 毛片在线免费观看完整版 | 欧美一级美国一级 | 国产精品区一区二区三区 | 欧美日韩国产一区二区三区在线观看 |