Ruby String

a="Ruby"
b='Ruby'
puts a==b

puts 'Hello \n world'            #在单引号中使用换行符
puts "Hello \n world"            #在双引号中使用换行符
puts 'it is\sok'                #在单引号中使用空白符
puts "it is\sook"                #在双引号中使用空白符
puts '\141'+" "+"\141"            #替换八进制数141所对应的字符
puts '\x52'+" "+"\x52"            #替换十六进制数x52所对应的字符
puts '\v'+" "+"\v"                #替换垂直Tab键对应字符
a="Ruby"
puts "I love #{a}"                #替换局部变量
puts 'I love #{a}'                #替换局部变量

name="汪路"
age=23
sex="男"
#使用%Q/stuff/形式创建多行文本字符串
info=%Q{个人信息调查    
姓名:#{name}
年龄:#{age}
性别:#{sex}
}
#使用%q/stuff/形式创建多行文本字符串
info1=%q{个人信息调查    
姓名:#{name}
年龄:#{age}
性别:#{sex}
}
puts info,info1

name="汪路"
age=23
sex="男"
info=<<deff                    #使用Here Document创建多行字符串
姓名:#{name}
年龄:#{age}
性别:#{sex}
deff
puts info

name="李玺"
department="Ruby研发部"
info=<<"deff"                    #对标识符使用双引号
姓名:#{name}
部门:#{department}
deff
info1=<<'deff'                    #对标识符使用单引号
姓名:#{name}
部门:#{department}
deff
puts info,info1

info1,info2=<<first,<<second
这是一个多行文本
这里是标识符first中的内容
first
这是一个多行文本
这里是标识符second中的内容
second
puts info1,info2
#分隔字符串
str="sdfj在顶替地sdfsdfsdghertjtj"
len=str.length
puts len
if(10>len)
  str1=str
else
  str1=str.split("")[0,10].to_s
end
puts str1

 

true
Hello \n world
Hello
 world
it is\sok
it is ook
\141 a
\x52 R
\v
I love Ruby
I love #{a}
个人信息调查    
姓名:汪路
年龄:23
性别:男
个人信息调查    
姓名:#{name}
年龄:#{age}
性别:#{sex}
姓名:汪路
年龄:23
性别:男
姓名:李玺
部门:Ruby研发部
姓名:#{name}
部门:#{department}
这是一个多行文本
这里是标识符first中的内容
这是一个多行文本
这里是标识符second中的内容
32
sdfj在顶

 

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])/, '') #=> "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=&gt; 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"

"x".chop.chop #=> ""</o></e>

posted @ 2012-08-13 10:36  残星  阅读(2091)  评论(0编辑  收藏  举报