Ruby中常用的字符串处理函数使用实例【转】

2017-08-11  本文已影响0人  难道_fa74

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')#=> "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 ".rstrip   #=> " hello"
" hello ".strip #=> "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"

String#split

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

将一个字符串用分隔符分割成一些子字符串,并返回一个包含这些子字符串的数组。
如果PATTERN部分是一个字符串,那么用它作分割符来分隔,如果PATTERN是一个空格,那么在空格处分割,并且临近的空格被忽略。
如果PATTERN是个正则表达式,那么在匹配PATTERN的地方分割,当PATTERN是长度为0的字符串,那么SPLIT将把字符串分割为单个字符
如果PATTERN被忽略,将用$;来分隔,如果$;没有设置(就是在默认状态),SPLIT将制定空格' '
如果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"] 保留了空格
上一篇下一篇

猜你喜欢

热点阅读