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=> 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>