このWikiページは、単一の文字をASCIIに変換する方法の一般的なアイデアを示しました http://en.wikibooks.org/wiki/Ruby_Programming/ASCII
しかし、文字列があり、それから各文字のアスキーを取得したい場合、どうすればよいですか?
"string".each_byte do |c|
$char = c.chr
$ascii = ?char
puts $ascii
end
行$ ascii =?charに満足していないため、機能しません。
syntax error, unexpected '?'
$ascii = ?char
^
c
変数には既にcharコードが含まれています!
"string".each_byte do |c|
puts c
end
利回り
115
116
114
105
110
103
puts "string".split('').map(&:ord).to_s
ruby1.9の変更については、この投稿を参照してください `?`(疑問符)を使用してASCIIでRuby文字コードを取得できません
Ruby Stringは、1.9.1以降のcodepoints
メソッドを提供します。
str = 'hello world'
str.codepoints.to_a
=> [104, 101, 108, 108, 111, 32, 119, 111, 114, 108, 100]
str = "你好世界"
str.codepoints.to_a
=> [20320, 22909, 19990, 30028]
単一の文字には「x」.ordを使用し、文字列全体には「xyz」.sumを使用します。
Each_byteまたはさらに良いString#bytesの後にto_aを呼び出すこともできます
=> 'hello world'.each_byte.to_a
=> [104, 101, 108, 108, 111, 32, 119, 111, 114, 108, 100]
=> 'hello world'.bytes
=> [104, 101, 108, 108, 111, 32, 119, 111, 114, 108, 100]
"a"[0]
または
?a
両方ともASCIIに相当します。