誰かこの結果を説明してくれませんか?
#!/usr/bin/env ruby
# encoding: utf-8
require 'rexml/document'
doc = REXML::Document.new(DATA)
puts "doc: #{doc.encoding}"
REXML::XPath.each(doc, '//item') do |item|
puts " #{item}: #{item.to_s.encoding}"
end
__END__
<doc>
<item>Test</item>
<item>Über</item>
<item>8</item>
</doc>
出力:
doc: UTF-8
<item>Test</item>: US-ASCII
<item>Über</item>: UTF-8
<item>8</item>: US-ASCII
REXML はドキュメントのエンコーディングを気にせず、各アイテムのエンコーディングを自動検出し始めるようです...encode('UTF-8')
元のエンコーディングが UTF-8 であるにもかかわらず、REXML から抽出した各文字列に運命づけられているのでしょうか? ここで何が起きてるの?