欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Ruby中常用的字符串處理函數(shù)使用實(shí)例

 更新時(shí)間:2015年01月22日 11:50:41   投稿:junjie  
這篇文章主要介紹了Ruby中常用的字符串處理函數(shù)使用實(shí)例,本文總結(jié)了Ruby中最常用的字符串處理函數(shù),如返回字符串的長(zhǎng)度、判斷字符串中是否包含另一個(gè)串、字符串插入、字符串分隔、默認(rèn)分隔符為空格等內(nèi)容,需要的朋友可以參考下

1.返回字符串的長(zhǎng)度

復(fù)制代碼 代碼如下:

str.length => integer

2.判斷字符串中是否包含另一個(gè)串
復(fù)制代碼 代碼如下:

str.include? other_str => true or false
"hello".include? "lo"   #=> true
"hello".include? "ol"   #=> false
"hello".include? ?h     #=> true

3.字符串插入
復(fù)制代碼 代碼如下:

str.insert(index, other_str) => str
"abcd".insert(0, 'X')    #=> "Xabcd"
"abcd".insert(3, 'X')    #=> "abcXd"
"abcd".insert(4, 'X')    #=> "abcdX"
"abcd".insert(-3, 'X')
-3, 'X')   #=> "abXcd"
"abcd".insert(-1, 'X')   #=> "abcdX"

4.字符串分隔,默認(rèn)分隔符為空格
復(fù)制代碼 代碼如下:

str.split(pattern=$;, [limit]) => anArray
" now's the time".split        #=> ["now's", "the", "time"]
"1, 2.34,56, 7".split(%r{,\s*}) #=> ["1", "2.34", "56", "7"]
"hello".split(//)               #=> ["h", "e", "l", "l", "o"]
"hello".split(//, 3)            #=> ["h", "e", "llo"]
"hi mom".split(%r{\s*})         #=> ["h", "i", "m", "o", "m"]
"mellow yellow".split("ello")   #=> ["m", "w y", "w"]
"1,2,,3,4,,".split(',')         #=> ["1", "2", "", "3", "4"]
"1,2,,3,4,,".split(',', 4)      #=> ["1", "2", "", "3,4,,"]

5.字符串替換
復(fù)制代碼 代碼如下:

str.gsub(pattern, replacement) => new_str
str.gsub(pattern) {|match| block } => new_str
"hello".gsub(/[aeiou]/, '*')              #=> "h*ll*"     #將元音替換成*號(hào)
"hello".gsub(/([aeiou])/, '<\1>')         #=> "h<e>ll<o>"   #將元音加上尖括號(hào),\1表示保留原有字符???
"hello".gsub(/./) {|s| s[0].to_s + ' '}   #=> "104 101 108 108 111 "

字符串替換二:
復(fù)制代碼 代碼如下:

str.replace(other_str) => str
s = "hello"         #=> "hello"
s.replace "world"   #=> "world"

6.字符串刪除
復(fù)制代碼 代碼如下:

str.delete([other_str]+) => new_str
"hello".delete "l","lo"        #=> "heo"
"hello".delete "lo"            #=> "he"
"hello".delete "aeiou", "^e"   #=> "hell"
"hello".delete "ej-m"          #=> "ho"

7.去掉前和后的空格
復(fù)制代碼 代碼如下:

str.lstrip => new_str
" hello ".lstrip   #=> "hello "
"hello".lstrip       #=> "hello"

8.字符串匹配
復(fù)制代碼 代碼如下:

str.match(pattern) => matchdata or nil

9.字符串反轉(zhuǎn)
復(fù)制代碼 代碼如下:

str.reverse => new_str
"stressed".reverse   #=> "desserts"

10.去掉重復(fù)的字符
復(fù)制代碼 代碼如下:

str.squeeze([other_str]*) => new_str
"yellow moon".squeeze                  #=> "yelow mon" #默認(rèn)去掉串中所有重復(fù)的字符
" now   is the".squeeze(" ")         #=> " now is the" #去掉串中重復(fù)的空格
"putters shoot balls".squeeze("m-z")   #=> "puters shot balls" #去掉指定范圍內(nèi)的重復(fù)字符

11.轉(zhuǎn)化成數(shù)字
復(fù)制代碼 代碼如下:

str.to_i=> str
"12345".to_i             #=> 12345

chomp和chop的區(qū)別:

chomp:去掉字符串末尾的\n或\r
chop:去掉字符串末尾的最后一個(gè)字符,不管是\n\r還是普通字符

復(fù)制代碼 代碼如下:

"hello".chomp            #=> "hello"
"hello\n".chomp          #=> "hello"
"hello\r\n".chomp        #=> "hello"
"hello\n\r".chomp        #=> "hello\n"
"hello\r".chomp          #=> "hello"
"hello".chomp("llo")     #=> "he"

"string\r\n".chop   #=> "string"
"string\n\r".chop   #=> "string\n"
"string\n".chop     #=> "string"
"string".chop       #=> "strin"

split是String類的一個(gè)類方法,我根據(jù)ri String.split提供的內(nèi)容簡(jiǎn)單翻譯一下。
----------------------------------------------------------- String#split
str.split(pattern=$;, [limit]) => anArray
------------------------------------------------------------------------
Divides _str_ into substrings based on a delimiter, returning an
array of these substrings.
將一個(gè)字符串用分隔符分割成一些子字符串,并返回一個(gè)包含這些子字符串的數(shù)組。

If _pattern_ is a +String+, then its contents are used as the
delimiter when splitting _str_. If _pattern_ is a single space,
_str_ is split on whitespace, with leading whitespace and runs of
contiguous whitespace characters ignored.
如果pattern部分是一個(gè)字符串,那么用它作分割符來(lái)分隔,如果pattern是一個(gè)空格,那么在空格處分割,并且臨近的空格被忽略。

If _pattern_ is a +Regexp+, _str_ is divided where the pattern
matches. Whenever the pattern matches a zero-length string, _str_
is split into individual characters.
如果pattern是個(gè)正則表達(dá)式,那么在匹配pattern的地方分割,當(dāng)pattern是長(zhǎng)度為0的字符串,那么split將把字符串分割為單個(gè)字符

If _pattern_ is omitted, the value of +$;+ is used. If +$;+ is
+nil+ (which is the default), _str_ is split on whitespace as if `
' were specified.
如果pattern被忽略,將用$;來(lái)分隔,如果$;沒(méi)有設(shè)置(就是在默認(rèn)狀態(tài)),split將制定空格' '
If the _limit_ parameter is omitted, trailing null fields are
suppressed. If _limit_ is a positive number, at most that number of
fields will be returned (if _limit_ is +1+, the entire string is
returned as the only entry in an array). If negative, there is no
limit to the number of fields returned, and trailing null fields
are not suppressed.
如果limit參數(shù)被忽略,跟蹤空段被抑制,如果limit是個(gè)正數(shù),那么至多返回limit個(gè)字段(如果是1,那么將整個(gè)字符串作為一個(gè)字段返回),如果是個(gè)負(fù)數(shù),那么跟蹤空段不被抑制。

" now's the time".split #=> ["now's", "the", "time"]
" now's the time".split(' ') #=> ["now's", "the", "time"]
" now's the time".split(/ /) #=> ["", "now's", "", "the", "time"]
"1, 2.34,56, 7".split(%r{,\s*}) #=> ["1", "2.34", "56", "7"]
"hello".split(//) #=> ["h", "e", "l", "l", "o"]
"hello".split(//, 3) #=> ["h", "e", "llo"]
"hi mom".split(%r{\s*}) #=> ["h", "i", "m", "o", "m"]

"mellow yellow".split("ello") #=> ["m", "w y", "w"]
"1,2,,3,4,,".split(' ,') #=> ["1", "2", "", "3", "4"]
"1,2,,3,4,,".split(',', 4) #=> ["1", "2", "", "3,4,,"]
"1,2,,3,4,,".split(',', -4) #=> ["1", "2", "", "3", "4", "", ""]

如果包含特殊字符,注意轉(zhuǎn)義
"wo | shi | yi | ge | bing".split(/\s*\|\s*) #豎杠別忘了轉(zhuǎn)義

還有它和String.scan的區(qū)別,split中的pattern是分隔符,而scan中的pattern指的是要匹配的東西。

"123=342=4234=523421=6424".scan(/\d+/) #=> ["123","342","4234","523421","6424"]


如果匹配項(xiàng)被括起來(lái),那么則會(huì)保留分割符,例如:

"Three little words".split(/\s+/) #===>["three","little",words"]
"Three little words".split(/(\s+)/) #===>["three"," ","little"," ","words"] 保留了空格

相關(guān)文章

  • 在Ruby中創(chuàng)建和使用哈希的教程

    在Ruby中創(chuàng)建和使用哈希的教程

    這篇文章主要介紹了在Ruby中創(chuàng)建和使用哈希的教程,羅列了Ruby中各種使用哈希的方法,需要的朋友可以參考下
    2015-04-04
  • Ruby面向?qū)ο缶幊讨蓄惖姆椒ㄅc類的擴(kuò)展

    Ruby面向?qū)ο缶幊讨蓄惖姆椒ㄅc類的擴(kuò)展

    類與方法是面向?qū)ο缶幊陶Z(yǔ)言中的典型特性,方法的概念與函數(shù)基本上相同,只不過(guò)類方法會(huì)受到類作用域的約束,這里我們就簡(jiǎn)單來(lái)看一下Ruby面向?qū)ο缶幊讨蓄惖姆椒ㄅc類的擴(kuò)展
    2016-06-06
  • ruby實(shí)現(xiàn)網(wǎng)頁(yè)圖片抓取

    ruby實(shí)現(xiàn)網(wǎng)頁(yè)圖片抓取

    本文給大家分享的是個(gè)人使用ruby編寫的抓取網(wǎng)頁(yè)圖片的代碼,十分的簡(jiǎn)單實(shí)用,有需要的小伙伴可以參考下。
    2015-06-06
  • Ruby on rails安裝后去掉DL is deprecated,please use Fiddle警告信息的方法【測(cè)試可用】

    Ruby on rails安裝后去掉DL is deprecated,please use Fiddle警告信息的方法【

    這篇文章主要介紹了Ruby on rails安裝后去掉DL is deprecated,please use Fiddle警告信息的方法,通過(guò)針對(duì)Ruby on rails安裝文件中的警告部分源碼進(jìn)行注釋來(lái)達(dá)到消除警告的目的,需要的朋友可以參考下
    2017-02-02
  • 實(shí)例解析Ruby中的數(shù)值類型以及常量

    實(shí)例解析Ruby中的數(shù)值類型以及常量

    這篇文章主要介紹了Ruby中的數(shù)值類型以及常量,是Ruby入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-10-10
  • 實(shí)例講解Ruby使用設(shè)計(jì)模式中的裝飾器模式的方法

    實(shí)例講解Ruby使用設(shè)計(jì)模式中的裝飾器模式的方法

    這篇文章主要介紹了Ruby使用設(shè)計(jì)模式中的裝飾器模式的實(shí)例, 裝飾模式能夠?qū)崿F(xiàn)動(dòng)態(tài)的為對(duì)象添加功能,需要的朋友可以參考下
    2016-03-03
  • 最新評(píng)論