欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Ruby中操作字符串的一些基本方法

程序员文章站 2022-04-28 22:42:12
 在ruby中的string对象持有和操纵的任意序列的一个或多个字节,通常表示人类语言的字符表示。 简单的字符串文本括在单引号(单引号字符)。引号内的文本的字符...

 在ruby中的string对象持有和操纵的任意序列的一个或多个字节,通常表示人类语言的字符表示。

简单的字符串文本括在单引号(单引号字符)。引号内的文本的字符串值:

'this is a simple ruby string literal'

如果需要内放置一个单引号,单引号的字符串文字,在它前面加上一个反斜杠ruby解释器不认为终止字符串:

'won\'t you read o\'reilly\'s book?'

反斜杠也可以转义另一个反斜杠,这样第二个反斜杠本身不是解释为转义字符。

以下是字符串相关的功能ruby的。
表达式替换:

表达式替换嵌入任何ruby表达式的值转换成字符串使用的一种手段,可用 #{ and }替换:

#!/usr/bin/ruby

x, y, z = 12, 36, 72
puts "the value of x is #{ x }."
puts "the sum of x and y is #{ x + y }."
puts "the average was #{ (x + y + z)/3 }."

这将产生以下结果:

the value of x is 12.
the sum of x and y is 48.
the average was 40.

一般分隔的字符串:

一般分隔的字符串,可以创建字符串匹配任意分隔符,比如,虽然包含在一对,如:., !, (, {, <, 等,前面加上一个百分号(%). q, q 和 x,有特殊的含义一般可以分隔的字符串。

%{ruby is fun.} equivalent to "ruby is fun."
%q{ ruby is fun. } equivalent to " ruby is fun. "
%q[ruby is fun.] equivalent to a single-quoted string
%x!ls! equivalent to back tick command output `ls`

转义字符:

下表是转义或反斜线符号可以表示非打印字符列表。

注: 在双引号的字符串,被解释为转义字符,在一个单引号字符的转义字符被保留。

Ruby中操作字符串的一些基本方法

 字符编码方式:

ruby的默认字符集是ascii码,字符可能会由单字节表示。如果使用utf-8或另一种现代的字符集,字符可能会以四个字节表示。

可以更改字符集使用$kcode的在程序的开始行,像这样:

$kcode = 'u'

以下是 $kcode 可能的值

Ruby中操作字符串的一些基本方法

 字符串的内置方法:

我们需要有一个string对象实例调用一个string方法。以下的方法来创建string对象的一个实例:

new [string.new(str="")]

这将返回一个新的字符串对象,其中包含str的一个副本。现在使用str的对象,我们可以任何可用实例方法的。例如:

#!/usr/bin/ruby

mystr = string.new("this is test")
foo = mystr.downcase

puts "#{foo}"

这将产生以下结果:

this is test

 字符串的解压指令:

下表列出了解压指令方法 string#unpack.

Ruby中操作字符串的一些基本方法

Ruby中操作字符串的一些基本方法

Ruby中操作字符串的一些基本方法

 例子:

试试下面的例子来解压缩各种数据。

"abc \0\0abc \0\0".unpack('a6z6')  #=> ["abc", "abc "]
"abc \0\0".unpack('a3a3')      #=> ["abc", " \000\000"]
"abc \0abc \0".unpack('z*z*')    #=> ["abc ", "abc "]
"aa".unpack('b8b8')         #=> ["10000110", "01100001"]
"aaa".unpack('h2h2c')        #=> ["16", "61", 97]
"\xfe\xff\xfe\xff".unpack('ss')   #=> [-2, 65534]
"now=20is".unpack('m*')       #=> ["now is"]
"whole".unpack('xax2ax2ax1ax2a')  #=> ["h", "e", "l", "l", "o"]