文章出處

字符串處理函數
1.返回字符串的長度

str.length => integer

 

2.判斷字符串中是否包含另一個串

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

 

3.字符串插入:

復制代碼
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.字符串分隔,默認分隔符為空格

復制代碼
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.字符串替換

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

字符串替換二:

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

 

6.字符串刪除:

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.去掉前和后的空格

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

 

8.字符串匹配

str.match(pattern) => matchdata or nil

 

9.字符串反轉

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

 

10.去掉重復的字符

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

 

11.轉化成數字

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

 

chomp和chop的區別:
chomp:去掉字符串末尾的\n或\r
chop:去掉字符串末尾的最后一個字符,不管是\n\r還是普通字符

復制代碼
"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類一個類方法,我根據ri String.split提供的內容簡單翻譯一下。

----------------------------------------------------------- String#split

         str.split(pattern=$;, [limit])       => anArray

------------------------------------------------------------------------

         Divides _str_ into substrings based on a delimiter, returning an

         array of these substrings.

將一個字符串用分隔符分割成一些子字符串,并返回一個包含這些子字符串的數組。

 

         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部分一個字符串,那么用它作分割符來分隔,如果pattern是一個空格,那么在空格處分割,并且臨近的空格被忽略。

 

         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是個正則達式,那么在匹配pattern的地方分割,當pattern是長度為0的字符串,那么split將把字符串分割為單個字符

 

         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被忽略,將用$;來分隔,如果$;沒有設置(就是在默認狀態),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參數被忽略,跟蹤空段被抑制,如果limit是個正數,那么至多返回limit個字段(如果是1,那么將整個字符串作為一個字段返回),如果是個負數,那么跟蹤空段不被抑制。

 

            " 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", "", ""]

 

如果包含特殊字符,注意轉義

"wo | shi | yi | ge | bing".split(/\s*\|\s*)              #豎杠別忘了轉義

 

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

 

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

 

 

如果匹配項被括起來,那么則會保留分割符,例如:

 

"Three little words".split(/\s+/)    #===>["three","little",words"]

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


文章列表




Avast logo

Avast 防毒軟體已檢查此封電子郵件的病毒。
www.avast.com


arrow
arrow
    全站熱搜
    創作者介紹
    創作者 大師兄 的頭像
    大師兄

    IT工程師數位筆記本

    大師兄 發表在 痞客邦 留言(0) 人氣()