2012-03-02 30 views
11

私は長さと内容の異なる文字列の配列を持っています。文章/文字列の最後の単語を抽出しますか?

今、私は各単語の最後の単語を抽出する簡単な方法を探しています。その単語の長さや文字列の長さはわかりません。

何か;

array.each{|string| puts string.fetch(" ", last) 

答えて

26

これは、それはあなたがcollect

配列から配列として "最後の言葉" を取得するには

delete、句読点を除外する
"my rando­m sente­nce..,.!?".­split.last­.delete('.­!?,') #=> "sentence" 

をうまく

"my random sentence".split.last # => "sentence" 

を動作するはずです

["random sentence...",­ "lorem ipsum!!!"­].collect { |s| s.spl­it.last.delete('.­!?,') } # => ["sentence", "ipsum"] 
+0

完璧な、私は正しい軌道にあった。ありがとう! – BSG

+1

スプリット機能にセパレータを付けることができると付け加えたいと思います。デフォルトでは、関数は空白を使用しますが、スラッシュやダッシュのような別のものに分割することもできます。 Ref:http://ruby-doc.org/core-2.2.0/String.html#method-i-split –

3
array_of_strings = ["test 1", "test 2", "test 3"] 
array_of_strings.map{|str| str.split.last} #=> ["1","2","3"] 
1
["one two",­ "thre­e four five"­].collect { |s| s.spl­it.last } 
=> ["two", "five"] 
1

"a string of words!".match(/(.*\s)*(.+)\Z/)[2] #=> 'words!'最後の空白のキャッチ。それには句読点も含まれます。

["a string of words", "Something to say?", "Try me!"].collect {|s| s.match(/(.*\s)*(.+)\Z/)[2] } #=> ["words", "say?", "me!"]

0

これは、私は考えることができる最も簡単な方法です:文字列の配列から、コレクトでそれを使用することを抽出するために

hostname> irb 
irb(main):001:0> str = 'This is a string.' 
=> "This is a string." 
irb(main):002:0> words = str.split(/\s+/).last 
=> "string." 
irb(main):003:0> 
関連する問題