萬盛學電腦網

 萬盛學電腦網 >> 網絡編程 >> 編程語言綜合 >> Ruby中操作字符串的一些基本方法

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

   這篇文章主要介紹了Ruby中操作字符串的一些基本方法,包括對字符串的壓縮和解壓縮等處理,需要的朋友可以參考下

  在Ruby中的String對象持有和操縱的任意序列的一個或多個字節,通常表示人類語言的字符表示。

  簡單的字符串文本括在單引號(單引號字符)。引號內的文本的字符串值:

  ?

1 'This is a simple Ruby string literal'

  如果需要內放置一個單引號,單引號的字符串文字,在它前面加上一個反斜槓Ruby解釋器不認為終止字符串:

  ?

1 'Won't you read O'Reilly's book?'

  反斜槓也可以轉義另一個反斜槓,這樣第二個反斜槓本身不是解釋為轉義字符。

  以下是字符串相關的功能Ruby的。

  表達式替換:

  表達式替換嵌入任何Ruby表達式的值轉換成字符串使用的一種手段,可用 #{ and }替換:

  ?

1 2 3 4 5 6 #!/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 }."

  這將產生以下結果:

  ?

1 2 3 The value of x is 12. The sum of x and y is 48. The average was 40.

  一般分隔的字符串:

  一般分隔的字符串,可以創建字符串匹配任意分隔符,比如,雖然包含在一對,如:., !, (, {, <, 等,前面加上一個百分號(%). Q, q 和 x,有特殊的含義一般可以分隔的字符串。

  ?

1 2 3 4 %{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`

  轉義字符:

  下表是轉義或反斜線符號可以表示非打印字符列表。

  注: 在雙引號的字符串,被解釋為轉義字符,在一個單引號字符的轉義字符被保留。

2015512110744315.jpg (581×573)

  字符編碼方式:

  Ruby的默認字符集是ASCII碼,字符可能會由單字節表示。如果使用UTF-8或另一種現代的字符集,字符可能會以四個字節表示。

  可以更改字符集使用$KCODE的在程序的開始行,像這樣:

  ?

1 $KCODE = 'u'

  以下是 $KCODE 可能的值

2015512110847229.jpg (603×190)

  字符串的內置方法:

  我們需要有一個String對象實例調用一個String方法。以下的方法來創建String對象的一個實例:

  ?

1 new [String.new(str="")]

  這將返回一個新的字符串對象,其中包含str的一個副本。現在使用str的對象,我們可以任何可用實例方法的。例如:

  ?

1 2 3 4 #!/usr/bin/ruby   myStr = String.new("THIS IS TEST") foo = myStr.downcase

  ?

1 puts "#{foo}"

  這將產生以下結果:

  ?

1 this is test

  字符串的解壓指令:

  下表列出了解壓指令方法 String#unpack.

2015512110915320.jpg (579×754)
2015512110934549.jpg (587×692)
2015512110955640.jpg (567×225)

  例子:

  試試下面的例子來解壓縮各種數據。

  ?

1 2 3 4 5 6 7 8 "abc abc ".unpack('A6Z6') #=> ["abc", "abc "] "abc ".unpack('a3a3') #=> ["abc", " 0000"] "abc abc ".unpack('Z*Z*') #=> ["abc ", "abc "] "aa".unpack('b8B8') #=> ["10000110", "01100001"] "aaa".unpack('h2H2c') #=> ["16", "61", 97] "xfexffxfexff".unpack('sS') #=> [-2, 65534] "now=20is".unpack('M*') #=> ["now is"] "whole".unpack('xax2aX2aX1aX2a') #=> ["h", "e", "l", "l", "o"]
copyright © 萬盛學電腦網 all rights reserved