《Rubu基础教程第五版》第十四章笔记 字符串类

字符串的创建可以通过""双引号或者''单引号进行创建

双引号的可以通过#{}的方式取出变量名的内容,单引号不行,输入什么,输出就是什么

 

irb(main):016:0> desc = %Q(Ruby的字符串用''和"")
=> "Ruby的字符串用''和\"\""
irb(main):017:0> puts desc
Ruby的字符串用''和""
=> nil
irb(main):018:0> str = %q(Ruby的字符串用''和"")
=> "Ruby的字符串用''和\"\""
irb(main):019:0> puts str
Ruby的字符串用''和""
=> nil
irb(main):020:0> p str
"Ruby的字符串用''和\"\""
=> "Ruby的字符串用''和\"\""
irb(main):021:0> p desc
"Ruby的字符串用''和\"\""
=> "Ruby的字符串用''和\"\""
irb(main):022:0> 

 使用%q可以不用使用转义输出""或者''实际测试,q大写与小写没有区别

 

使用Here Document

Here Document来源与shell的一种程序写法,使用<<来创建字符串

标准版写法

<<"结束标识符"

字符串内容

结束标识符

结束标识符可以用""或者''。区别见前面,如果啥度没写,默认的效果等于""

使用EOF  "End Of File"的缩写,或者EOB "End of Block"的缩写

 

Here Document的结束标识符一定要在行首

irb(main):022:0> 10.times do |i|
irb(main):023:1*   print(<<"EOB")
irb(main):024:2" i:#{i}
irb(main):025:2" EOB
irb(main):026:1> end
i:0
i:1
i:2
i:3
i:4
i:5
i:6
i:7
i:8
i:9
=> 10

 

这样缩进不好看,可以通过<<-,这样程序会忽略结束标识符前的空格和制表符,结束标识符可以不在行首了

irb(main):027:0> 10.times do |i|
irb(main):028:1*   print(<<-EOB)
irb(main):029:2" i: #{i}
irb(main):030:2"   EOB
irb(main):031:1> end
i: 0
i: 1
i: 2
i: 3
i: 4
i: 5
i: 6
i: 7
i: 8
i: 9
=> 10
irb(main):032:0> 

 

可以用<<~来忽略行首的空白,这样一来.i :#{i}也可以缩进了

irb(main):032:0> 10.times do |i|
irb(main):033:1*   print(<<~EOB)
irb(main):034:2"     i: #{i}
irb(main):035:2"   EOB
irb(main):036:1> end
i: 0
i: 1
i: 2
i: 3
i: 4
i: 5
i: 6
i: 7
i: 8
i: 9
=> 10

 

还可以通过Here Document赋值给变量

irb(main):037:0> str = <<~EOB
irb(main):038:0" hello
irb(main):039:0" world
irb(main):040:0" EOB
=> "hello\nworld\n"
irb(main):041:0> puts str
hello
world
=> nil
irb(main):042:0> 

 

sprintf等于format

 

脚本里面使用``来调用linux命令,这个跟shell脚本一样

irb(main):044:0> info = `who am i`
=> "sjz      pts/105      2020-06-05 16:08 (172.168.131.111)\n"
irb(main):045:0> puts info
sjz      pts/105      2020-06-05 16:08 (172.168.131.111)
=> nil
irb(main):046:0> 

 

printf 与 sprontf方法

printf与C语言的操作的比较像

sprintf与Python中的format差不多

irb(main):046:0> n = 65535
=> 65535
irb(main):047:0> printf("%d用十六进制表示为&x\n",n,n)
65535用十六进制表示为&x
=> nil
irb(main):048:0> printf("%d用十六进制表示为%x\n",n,n)
65535用十六进制表示为ffff
=> nil
irb(main):050:0> p sprintf("%d用十六进制表示为%x\n",n,n)
"65535用十六进制表示为ffff\n"
=> "65535用十六进制表示为ffff\n"
irb(main):051:0> 

 sprintf与format使用一样

irb(main):051:0> p format("Hello, %s!","Ruby")
"Hello, Ruby!"
=> "Hello, Ruby!"
irb(main):052:0> format("Hello, %s!","Ruby")
=> "Hello, Ruby!"
irb(main):053:0> 

 

标记、最小宽度、精度跟Python的print %格式化输出差不多

#b %B、%o、%x、%X,输出加上前缀后的结果(0b、0B、0、0x、0X)

书写的真的很烂,直接上一些代码,演示下算了

>> printf("%8s", "Ruby")
    Ruby=> nil
>> printf("%8.8s", "Hello Ruby")
Hello Ru=> nil
>> printf("%#010x", 100)
0x00000064=> nil
>> printf("%#020x", 100)
0x000000000000000064=> nil
>> printf("%+ .2f", Math::PI)
+3.14=> nil
>> printf("%*.*f",5,2, Math::PI)
 3.14=> nil
>> 

 

获取字符串的长度

.length或.size获取字符长度 .bytesize获取字节长度,.empty?查寻是否为空

 

字符串的索引,跟列表操作一样

>> str = "Rubu is a good language"
=> "Rubu is a good language"
>> str[1..3]
=> "ubu"
>> str[2,3]
=> "bu "
>> str[1] = 15
Traceback (most recent call last):
        5: from /usr/bin/irb:23:in `<main>'
        4: from /usr/bin/irb:23:in `load'
        3: from /Library/Ruby/Gems/2.6.0/gems/irb-1.0.0/exe/irb:11:in `<top (required)>'
        2: from (irb):4
        1: from (irb):4:in `[]='
TypeError (no implicit conversion of Integer into String)
>> str[1] = "15"
=> "15"
>> str
=> "R15bu is a good language"
>> 

 

字符串的连接

合并一个新的字符用 +号,扩展原有的字符用<<用了+=叶可以,一般使用<<与cncat更加有效率

 

字符串的比较,如果直接比较是更具asci的大小进行比较的

 

字符串的分割

split 可以通过//的方式用正则来切

 

去换换行符,或者取出最后一个字符

shop与chon!去除最后一个字符

chomp与chomp去除最后一个换行符

>> a
=> "123\n"
>> a.chop
=> "123"
>> a.chomp
=> "123"
>> b = "123"
=> "123"
>> b.chop
=> "12"
>> b.chomp
=> "123"
>> 

 

字符串的检索和替换

>> str = "shijianzhong"
=> "shijianzhong"
>> str.index("i")
=> 2
>> str.rindex("i")
=> 4
>> str.include?("jian")
=> true
>> [1,2,3].include?(2)
=> true
>> 

 

字符串与数组的共同方法

与索引相关

取值用s[n],s[n..m],s[n, m]

与s.slice(n),s.slice(n..m),s.slice(n, m)相同的效果

slice!是删除字符的一部分,并返回删除的部分

 

返回Enumerator对象的方法

通过str.each_line, .each_char, .each_byte等可以返回一个Enumerator对象

>> str = "a\nb\nc\n"
=> "a\nb\nc\n"
>> tmp = str.each_line.collect do |line|
?>  line.chomp! * 3
>> end
=> ["aaa", "bbb", "ccc"]
>> 
>> str = "abcde"
=> "abcde"
>> tmp = str.each_byte.collect do |byte|
?>   -byte
>> end
=> [-97, -98, -99, -100, -101]
>> tmp
=> [-97, -98, -99, -100, -101]
>> 

 

与连接、反转相关的方法

s.concat(s2)

已经演示了

 

s.delete(str)

返回删除以后的字符

>> str = "I love you"
=> "I love you"
>> str.delete('love')
=> "I  yu"
>> str
=> "I love you"
>> str.delete!('love')
=> "I  yu"
>> str
=> "I  yu"
>> 

 

s.strip  upcase downcase swapcase capitalize  字符串的一些方法

tr用于替换字符

>> str = "abcde"
=> "abcde"
>> str.tr("ab","c")
=> "cccde"
>> 

 把需要的字符转成成指定的字符

 

联系题

这个字符字符串切割并排序,Ruby is an object oriented programming language

str = "Ruby is an object oriented programming language"
str_array = str.split
p str_array
str_array.sort!{|a,b| a<=>b}
p str_array

 3 不区分大小写进行排序

str = "Ruby is an object oriented programming language"
str_array = str.split
p str_array
str_array.sort!{|a,b| a.downcase<=>b.downcase}
p str_array          

 

4把1的字符串的全部单词字符首字母变成大写

str = "Ruby is an object oriented programming language"
str_array = str.split
str_array = str_array.collect {|str| str.capitalize}
str = str_array.join(" ")
p str

 

5 ,统计1中的字符输出.

str = "Ruby is an object oriented programming language"

count = Hash.new(0)

str.each_char do |char|
  count[char] += 1
end

count.each {|k,v| 
  puts "#{k}: " + "*" * v

}
# p count

 

 

6定义中文转阿拉伯数字,这个不写了

 

posted @ 2020-06-06 17:44  就是想学习  阅读(195)  评论(0编辑  收藏  举报