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

  • 相关阅读:
    最小生成数kruskal算法和prim算法
    图的表示及遍历
    mysql忘记root用户密码重置密码的方式
    dwr2.0版本的demo
    web.xml中不同版本的servlet头以及版本控制
    初学jboss
    Filter学习总结,顺便提及点servlet3.0异步filter和异步监听
    监听器
    问题发现和解决
    linux学习
  • 原文地址:https://www.cnblogs.com/mingforyou/p/2635918.html
Copyright © 2020-2023  润新知