Ruby 字符串處理
更新時(shí)間:2007年11月24日 13:04:29 作者:
Ruby將字符串像數(shù)字一樣處理.我們用單引號(hào)('...')或雙引號(hào)("...")將它們括起來(lái).
ruby> "abc"
"abc"
ruby> 'abc'
"abc"
單引號(hào)和雙引號(hào)在某些情況下有不同的作用.一個(gè)由雙引號(hào)括起來(lái)的字符串允許字符由一個(gè)前置的斜杠引出,而且可以用#{}內(nèi)嵌表達(dá)式.而
單引號(hào)括起來(lái)的字符串并不會(huì)對(duì)字符串作任何解釋;你看到的是什么便是什么.幾個(gè)例子:
ruby> print "a\nb\nc","\n"
a
c
nil
ruby> print 'a\nb\n',"\n"
a\nb\nc
nil
ruby> "\n"
"\n"
ruby> '\n'
"\\n"
ruby> "\001"
"\001"
ruby> '\001'
"\\001"
ruby> "abcd #{5*3} efg"
"abcd 15 efg"
ruby> var = " abc "
" abc "
ruby> "1234#{var}5678"
"1234 abc 5678"
Ruby的字符串操作比C更靈巧,更直觀.比如說(shuō),你可以用+把幾個(gè)串連起來(lái),用*把一個(gè)串重復(fù)好幾遍:
ruby> "foo" + "bar"
"foobar"
ruby> "foo" * 2
"foofoo"
相比之下,在C里,因?yàn)樾枰_的內(nèi)存管理,串聯(lián)字符串要笨拙的多:
char *s = malloc(strlen(s1)+strlen(s2)+1);
strcpy(s, s1);
strcat(s, s2);
/* ... */
free(s);
但對(duì)于Ruby,我們不需要考慮字符串的空間占用問(wèn)題,這令到我們可以從煩瑣的內(nèi)存管理中解脫出來(lái).
下面是一些字符串的處理,
串聯(lián):
ruby> word = "fo" + "o"
"foo"
重復(fù):
ruby> word = word * 2
"foofoo"
抽取字符(注意:在Ruby里,字符被視為整數(shù)):
ruby> word[0]
102 # 102 is ASCII code of `f'
ruby> word[-1]
111 # 111 is ASCII code of `o'
(負(fù)的索引指從字符串尾算起的偏移量,而不是從串頭.)
提取子串:
ruby> herb = "parsley"
"parsley"
ruby> herb[0,1]
"p"
ruby> herb[-2,2]
"ey"
ruby> herb[0..3]
"pars"
ruby> herb[-5..-2]
"rsle"
檢查相等:
ruby> "foo" == "foo"
true
ruby> "foo" == "bar"
false
注意:在Ruby 1.0里,以上結(jié)果以大寫(xiě)字母出現(xiàn).
好,讓我們來(lái)試試這些特性.下面是一個(gè)猜詞的謎題,可能"謎題"這個(gè)詞用在下面的東西上太酷了一點(diǎn);-)
# save this as guess.rb
words = ['foobar', 'baz', 'quux']
secret = words[rand(3)]
print "guess? "
while guess = STDIN.gets
guess.chop!
if guess == secret
print "You win!\n"
break
else
print "Sorry, you lose.\n"
end
print "guess? "
end
print "The word was ", secret, ".\n"
現(xiàn)在,別太擔(dān)心代碼細(xì)節(jié)了.下面是謎題程序運(yùn)行的一個(gè)對(duì)話.
% ruby guess.rb
guess? foobar
Sorry, you lose.
guess? quux
Sorry, you lose.
guess? ^D
The word was baz.
(考慮到1/3的成功率,也許我本該做得好一點(diǎn).)
ruby> "abc"
"abc"
ruby> 'abc'
"abc"
單引號(hào)和雙引號(hào)在某些情況下有不同的作用.一個(gè)由雙引號(hào)括起來(lái)的字符串允許字符由一個(gè)前置的斜杠引出,而且可以用#{}內(nèi)嵌表達(dá)式.而
單引號(hào)括起來(lái)的字符串并不會(huì)對(duì)字符串作任何解釋;你看到的是什么便是什么.幾個(gè)例子:
ruby> print "a\nb\nc","\n"
a
c
nil
ruby> print 'a\nb\n',"\n"
a\nb\nc
nil
ruby> "\n"
"\n"
ruby> '\n'
"\\n"
ruby> "\001"
"\001"
ruby> '\001'
"\\001"
ruby> "abcd #{5*3} efg"
"abcd 15 efg"
ruby> var = " abc "
" abc "
ruby> "1234#{var}5678"
"1234 abc 5678"
Ruby的字符串操作比C更靈巧,更直觀.比如說(shuō),你可以用+把幾個(gè)串連起來(lái),用*把一個(gè)串重復(fù)好幾遍:
ruby> "foo" + "bar"
"foobar"
ruby> "foo" * 2
"foofoo"
相比之下,在C里,因?yàn)樾枰_的內(nèi)存管理,串聯(lián)字符串要笨拙的多:
char *s = malloc(strlen(s1)+strlen(s2)+1);
strcpy(s, s1);
strcat(s, s2);
/* ... */
free(s);
但對(duì)于Ruby,我們不需要考慮字符串的空間占用問(wèn)題,這令到我們可以從煩瑣的內(nèi)存管理中解脫出來(lái).
下面是一些字符串的處理,
串聯(lián):
ruby> word = "fo" + "o"
"foo"
重復(fù):
ruby> word = word * 2
"foofoo"
抽取字符(注意:在Ruby里,字符被視為整數(shù)):
ruby> word[0]
102 # 102 is ASCII code of `f'
ruby> word[-1]
111 # 111 is ASCII code of `o'
(負(fù)的索引指從字符串尾算起的偏移量,而不是從串頭.)
提取子串:
ruby> herb = "parsley"
"parsley"
ruby> herb[0,1]
"p"
ruby> herb[-2,2]
"ey"
ruby> herb[0..3]
"pars"
ruby> herb[-5..-2]
"rsle"
檢查相等:
ruby> "foo" == "foo"
true
ruby> "foo" == "bar"
false
注意:在Ruby 1.0里,以上結(jié)果以大寫(xiě)字母出現(xiàn).
好,讓我們來(lái)試試這些特性.下面是一個(gè)猜詞的謎題,可能"謎題"這個(gè)詞用在下面的東西上太酷了一點(diǎn);-)
# save this as guess.rb
words = ['foobar', 'baz', 'quux']
secret = words[rand(3)]
print "guess? "
while guess = STDIN.gets
guess.chop!
if guess == secret
print "You win!\n"
break
else
print "Sorry, you lose.\n"
end
print "guess? "
end
print "The word was ", secret, ".\n"
現(xiàn)在,別太擔(dān)心代碼細(xì)節(jié)了.下面是謎題程序運(yùn)行的一個(gè)對(duì)話.
% ruby guess.rb
guess? foobar
Sorry, you lose.
guess? quux
Sorry, you lose.
guess? ^D
The word was baz.
(考慮到1/3的成功率,也許我本該做得好一點(diǎn).)
您可能感興趣的文章:
- Ruby學(xué)習(xí)筆記之gem 命令詳解
- Ruby rails 頁(yè)面跳轉(zhuǎn)(render和redirect_to)
- RUBY 新手教程 跟我一起學(xué)ruby
- 學(xué)習(xí)Ruby你需要了解的相關(guān)知識(shí)(rvm, gem, bundle, rake, rails等)
- Ruby中執(zhí)行Linux shell命令的六種方法詳解
- 淘寶網(wǎng)提供的國(guó)內(nèi)RubyGems鏡像簡(jiǎn)介和使用方法
- 二十分鐘 教你Ruby快速入門(mén) 圖文教程
- 詳解Ruby中正則表達(dá)式對(duì)字符串的匹配和替換操作
- Ruby Gems更換淘寶源方法
- Windows下Ruby on Rails開(kāi)發(fā)環(huán)境安裝配置圖文教程
- ruby 學(xué)習(xí)筆記(2) 類的基本使用
- ruby 異常處理:rescue
- CentOS 6.3下編譯安裝Ruby 2.0筆記
- Ruby中的return、break、next詳解
- 舉例講解Ruby中require的使用方法
- 更改RubyGem安裝源
- 使用Ruby來(lái)處理JSON的簡(jiǎn)單教程
- Ruby信號(hào)處理詳解
相關(guān)文章
Ruby的XML格式數(shù)據(jù)解析庫(kù)Nokogiri的使用進(jìn)階
這篇文章主要介紹了Ruby的XML格式數(shù)據(jù)解析庫(kù)Nokogiri的使用進(jìn)階,文中對(duì)其從HTML/XML中抓取字段還有特別是命名空間的用法進(jìn)行了深入講解,需要的朋友可以參考下2016-04-04
CentOS7下搭建ruby on rails開(kāi)發(fā)環(huán)境
聽(tīng)說(shuō)rails是一個(gè)比較流行的快速開(kāi)發(fā)框架,對(duì)于我這個(gè)web不熟悉的人來(lái)說(shuō),那是極好的!可以快速上手,又能真正了解服務(wù)器端的各種,所以rails搞起來(lái)。不過(guò)一個(gè)完整的開(kāi)發(fā)環(huán)境搭建過(guò)程完成后,真的只能用各種坑來(lái)形容~2016-02-02
Monkey Patch猴子補(bǔ)丁編程方式及其在Ruby中的運(yùn)用
Monkey Patch是指在程序運(yùn)行時(shí)追加代碼段,一般被認(rèn)為是解釋型語(yǔ)言的特長(zhǎng),下面我們就來(lái)看一下Monkey Patch猴子補(bǔ)丁編程方式及其在Ruby中的運(yùn)用2016-05-05

