将字符串中的单个字符作为单字符字符串检索的Ruby惯用方法是什么?当然也有str[n]
方法,但(从Ruby1.8开始)它以fixnum形式返回字符代码,而不是字符串。如何获得单字符串?
发布于 2008-12-17 11:42:06
在Ruby1.9中,这很简单。在Ruby 1.9中,string是编码感知的字符序列,所以您只需对其进行索引,就可以从中获得一个单字符的字符串:
'µsec'[0] => 'µ'
然而,在Ruby1.8中,字符串是字节序列,因此完全不知道编码。如果对字符串进行索引,而该字符串使用多字节编码,则有可能直接索引到多字节字符的中间(在本例中,'µ‘是以UTF-8编码的):
'µsec'[0] # => 194
'µsec'[0].chr # => Garbage
'µsec'[0,1] # => Garbage
然而,Regexp和一些专门的字符串方法至少支持流行编码的一小部分,其中包括一些日语编码(例如Shift-JIS)和(在本例中) UTF-8:
'µsec'.split('')[0] # => 'µ'
'µsec'.split(//u)[0] # => 'µ'
发布于 2008-12-16 13:51:39
在Ruby 1.9之前:
'Hello'[1].chr # => "e"
Ruby 1.9+:
'Hello'[1] # => "e"
包括string semantics在内的很多Ruby1.9中都有changed。
发布于 2008-12-16 14:45:39
应该适用于Ruby 1.9之前和之后的版本:
'Hello'[2,1] # => "l"
请参阅Jörg Mittag的评论:这只适用于单字节字符集。
https://stackoverflow.com/questions/371333
复制相似问题