Ruby String常用函数

来源:互联网 发布:dva矩阵吸大 编辑:程序博客网 时间:2024/05/16 10:37

1、 单引号中的字符串

单引号的字符串中,连续两个\会被一个\替换

例:

‘nds\\’  #->  nds\

‘nds\\\’  #-> 出错

‘nds\\\y’  #->  nds\\y

‘nds\\\\’ # ->  nds\\

 

2、 单引号中的\’,会被替换为’

例:

‘nds\’’  #-> nds’

‘nds\’\\’ #-> 出错

 

3、  +将字符串连接起来

例:

'abc' + 'def'       #=> 'abcdef'

 

4、 字符串的内容重复times

str * times

例:

"abc" * 4       #=> "abcabcabcabc"

 

5、 双引号下的字符串

可支持全部的转义字符及用#{exp}将Ruby中的值插入字符串中

例:

i = 5

str = “ abab#{i}cjd”  #->abab5cjd

“#{ho *3} happy new year”  #->ho ho ho happy new year

 

6、 返回字符串的长度

str.length => integer

str.size=> integer

 

例如:

“string”.length       #->5          # 字符串的长度

“string”.size         #->5                # 字符串的长度

 

7、 判断字符串中是否包含另一个串 

str.include? other_str => true or false

 

例如:“string”.include?”in”  #->true         # 检查string中是否包含in

 

8、 字符串插入 

str.insert(index, other_str)=> str

 

例如:

        “string”.insert(0,‘a’)    #-> astring             # 在指标为0的位置插入a,指标从0起

“string”.insert(-1,‘a’)    #-> stringa           # 逆向指标为-1的位置插入a,指标从-1起

 

9、 字符串分隔,默认分隔符为空格 

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

 

例如:

“string  abc”.split    #->[“string” ,”abc”]   # 将字符串进行分割,默认的分隔符为空格

“string abc”.split(“ab”)    #->[“string  ” ,” c”] # 将字符串以ab为分隔符进行进行分割

"1,2,,3,4,,".split(',',4)     # -> ["1","2", "", "3,4,,"] # split的第二个参数用于限制分割后的部分数

10、  字符串替换

str.sub(patternreplace)                          str.gsub(patternreplace)

str.sub!(patternreplace)                                                           str.gsub!(patternreplace)

str.sub(pattern) {|matched| ... }                                                        str.gsub(pattern){|matched| ... }

str.sub!(pattern) {|matched| ...}                                             str.gsub!(pattern){|matched| ... }

str.replace(other_str)=> str                # replace来替换整个str,str本身也被改变。

sub生成并返回替换后的字符串。而sub!会修改str本身并返回结果。若没有进行替换时返回nil。sub只替换第一次匹配的部分,gsub替换所有匹配的部分。

例如:

str = “hello”               

str.sub(/[aeiou]/, '*')       #->"h*llo"      # str = “hello”

str.sub!(/[aeiou]/, '*')        #->"h*llo"      # str = "h*llo"

str.gsub(/[aeiou]/, '*')        #-> "h*ll*"      #将元音替换成*号

str.gsub(/./){|s| s[0]+’ ‘}        #-> "h e l l l o"    #将所有元素后加空格

str.replace(“he”)             #->”he”       #str=” he”

 

11、   字符串删除

str.delete([other_str]+) => new_str   #删除参数交集出现的所有字符,返回一个新字符串

str. delete! ([other_str]+) => str   #原字符串会被改变

 

例:

"hello".delete "l","lo"          #-> "heo"  #删掉所有的l

"hello".delete "lo"             #-> "he" #删掉所有的l及o

 

12、   去掉空白(\t\r\n\f\v

str. strip => new_str               #删除头部和尾部的空白

str.strip! =>str                                 #删除头部和尾部的空白,原字符串本身被改变,若无删除动作,则返回nil,str本身不变

str.lstrip => new_str               #删除头部的空白

str. lstrip !=> str                                      #删除头部的空白,原字符串本身被改变,若头部无空白,则返回nil,str本身不变

str.rstrip => new_str              #删除尾部的空白

str.rstrip !=> str                                     #删除尾部的空白,原字符串本身被改变,若尾部无空白,则返回nil,str本身不变

 

例:

p " abc\n".lstrip     #=>"abc\n"

p "\t abc\n".lstrip   #=> "abc\n"

p "abc\n".lstrip      #=> "abc\n"

 

str = "\nabc"

p str.lstrip           #=>"abc"

p str                  #=>"\nabc"  (无变化)

 

str = "  abc"

p str.lstrip!          #=>"abc"

p str                  #=>"abc"  (有变化)

 

str = "abc"

p str.lstrip!          #=>nil

p str                  #=>"abc"

 

13、   字符串匹配

str.match(pattern)=> matchdata or nil

例:

 puts “hello”.match(/ll./)   #=> <MatchData “llo”>

 

14、   字符串反转

str.reverse => new_str

str.reverse !=> str       #str本身会改变

 

    例:

"hello".reverse     #=> "olleh"

 

15、   去掉重复的字符

str.squeeze([other_str]*) => new_str

str.squeeze!([other_str]*) => str            #str本身被改变,若无删除动作,返回nil,

                                                                                           str不变

例:

"hello moon".squeeze     #=> "helo mon"   #默认去掉串中所有重复的字符

" hello moon  ".squeeze(" ")  #=> " hello moon "   #去掉串中重复的空格

" hello moon”. squeeze ("m-z")     #=> " hello mon " #去掉指定范围内的重复字符

 

16、   字符串转化成数字     

to_f:将字符串看作是10进制数形式,并将其变为浮点数Float。将不能被看作浮点数的那个部分之前的内容变为浮点数。若变换对象是空字符串则返回 0.0 。

         例:

p "10".to_f    #=> 10.0

p "10e2".to_f  #=> 1000.0

p "e2".to_f  # =>0.0      #头部第一个字符不可被看作浮点数

p "1e-2".to_f  #=> 0.01

p ".1".to_f    #=> 0.1

p " \n10".to_f # => 10.0       # 头部的空白被忽略

p "1_0_0".to_f # => 100.0        # `_' 被忽略

p "".to_f      #=> 0.0

 

to_i:将字符串看作是10进制数形式,并将其变为整数。若遇到不能变为整数的字符,就将它前面的内容变为整数。若变换对象为空字符串,则返回0。

例:

p " 10".to_i    #=> 10

p " 10e2".to_i    #=> 10

p "1e-2".to_f  #=> 1

p "010".to_i    #=> 10

p "-010".to_i   #=> -10

p "0x11".to_i   #=> 0

p ".1".to_i  # =>0

 

to_i(base) :通过指定不同的基数,还可以进行2~36进制的转换。若指定为0时,则通过 prefix 来判断基数(相反地,只有将其指定为0时,才会识别prefix)。若使用了0、2~36之外的参数时,会引发ArgumentError异常。

         例:

p "0b10".to_i(0)  #=> 2

p "0b10".to_i(2)  #=> 2

p "0o10".to_i(0)  # => 8

p "010".to_i(0)   #=> 8

p "0d10".to_i(0)  #=> 10

p "0d10".to_i(8)  #=> 0

p "0x10".to_i(0)  #=> 16

 

17、   删除字符串的最后的字符

str.chop :删除字符串str的最后一个字符,并返回新字符串

#若字符串以\r\n结尾,则两个字符都删去

#若字符串为空串,则返回空串

str.chop !:修改str本身并返回结果,若没做修改,则返回nil。

         例:

"string\r\n".chop           #->"string"

"string\n\r".chop           #->"string\n"

"string".chop                          #->"strin"

"s".chop.chop                #->""

 

str.chomp(endstr) :删除str的后缀endstr,如果未指定endstr,则删除回车换行符(\r、\n和\r\n);若endstr的取值是nil的话,将不作任何的动作。

str.chomp!(endstr) :修改str本身并返回结果,若没做修改,则返回nil。

例:

"hello\r\n".chomp                        #->"hello"

"hello".chomp("lo")                     #->"hel"

"hello".chomp("l")                        #->nil

 

18、   格式化字符串

arg为数组时,使用sprintf(self,*args)

arg为非数组时,使用sprintf(self,args)

         例:

name = "Bob"

age = 28

str = sprintf("Hi, %s... I see you're %d years old.", name, age)    #->”Hi, Bob... I see you're 28 

                                                                                                                                    years old”

格式 字符串

例:

p "%#x"     % 10       # => "0xa"

p "%#x,%#o" % [10, 10]  # => "0xa,012"

 

str.center(width)

str.ljust(width)

str.rjust(width)

str.center(width[,padding])

str.ljust(width[,padding])

str.rjust(width[,padding])

分别返回居中、靠左、靠右的字符串,当字符串长度超过width时,将返回原字符串的拷贝;若使用了第二参数padding的话,将使用padding来填充空白。

例:

str = "Moby-Dick"

s1 = str.ljust(13)            #"Moby-Dick    "

s2 = str.center(13)                #"  Moby-Dick  "

s3 = str.rjust(13)                   #"    Moby-Dick"

s4 = str.rjust(13)                   #"****Moby-Dick"

str.center(1).id== str.id   # => false      #返回原字符串的拷贝

 

19、   控制字符串的大小写

str.capitalize:将首字符(若为字母的话)改为大写字母,其余的改为小写字母,生成并返回

修改后的字符串。。

str.capitalize!:会修改str本身并返回结果,若未作修改时返回nil。

例:

"foobar".capitalize              # => "Foobar"

 

str.downcase:将字符串中的大写字母都改为小写字母,生成并返回修改后的字符串

str.downcase!:会修改str本身并返回结果,若没有作修改,则返回nil.

str.upcase:将字符串中的小写字母都改为大写字母,生成并返回修改后的字符串

str.upcase!:会修改str本身并返回结果,若没有作修改,则返回nil.

str. swapcase:将所有的大写字母改为小写字母,小写字母改为大写字母,生成并返回

修改后的字符串

str. swapcase!:会修改str本身并返回结果,若没有作修改,则返回nil.

例:

s = "Hello,World"

s.downcase                      #"hello,world"

s.upcase                         #"HELLO,WORLD"

s.swapcase                        #"hELLO,wORLD"

 

20、   字符串的匹配

“=~”:与正则表达式的匹配           

例:

if string =~ /[a-z]/     #检查字符串中是否有小写字符

  puts "string contains lowercase charcters"

end

if string =~ /[A-Z]/               #检查字符串中是否有大写字符

  puts "string contains uppercase charcters"

end

if string =~ /[A-Z]/ and string =~ /a-z/  #检查字符串中是否既有大写又有小写字符

  puts "string contains mixed case"

end

if string[0..0] =~ /[A-Z]/         #检查字符串中第一个字符是否大写

  puts "string starts with a capital letter"

end

???????

p “AhdhBBN”=~/[A-Z]/   返回0

[v1] 

字符串与正则相关的方法还有matchscan,match返回第一个匹配对象,scan返回所有符合正则表达式的数组

例:

“hello”.match(/[a-h]/)             #<MatchData “h”>

“hello”.scan(/[a-h]/)                               #[“h”,”e”]

 

 

21、   字符串的子串

str[num1,num2]:num1代表取字符串的偏移位置,num2表示取的长度,其中num1可以是负数:

例:

str = "Humpty Dumpty"

sub1 = str[7,4]         # "Dump"

sub2 = str[7,99]        # "Dumpty" (超过的长度按实际长度来取)

sub3 = str[10,-4]       # nil (长度为负数了)

 

   str1 = "Alice"

     sub1 = str1[-3,3]   # "ice"

    str2 = "Through the Looking-Glass"

    sub3 = str2[-13,4]  # "Look"

 

Range取子串:利用脚标取子串

例:

        str = "Winston Churchill"

        sub1 = str[8..13]    # "Church"

        sub2 = str[-4..-1]   # "hill"

        sub3 = str[-1..-4]   # “”

     sub4 = str[25..30]   # nil

 

     str = "Alistair Cooke"

    sub1 = str[/l..t/]   # "list"

    sub2 = str[/s.*r/]   # "stair"

    sub3 = str[/foo/]    # nil

 

如果给出的是一个字符串,则如果目标字符串中含有这个给出的字符串,则返回这个给出的字符串,否则返回nil:

         str = "theater"

         sub1 = str["heat"]  # "heat"

         sub2 = str["eat"]   # "eat"

           sub3 = str["ate"]   # "ate"

         sub4 = str["beat"]  # nil

          sub5 = str["cheat"] # nil

如果给出的是一个数字,则返回的是该数字对应索引处字符的ASCII码:

   str = "Aaron Burr"

   ch1 = str[0]     #A

   ch1 = str[1]     #a

ch3 = str[99]    # nil

原创粉丝点击