문제

I get the following error when running the code below:

invalid byte sequence in UTF-8 (ArgumentError)

The code:

require 'hpricot'
require 'open-uri'

doc = open('http://www.amazon.co.jp/') {|f| Hpricot(f.read) }
puts doc.to_html

Hpricot cannot parse the Japanese content. Any suggestions on fixing this issue?

도움이 되었습니까?

해결책

The site doesn't seem to be using UTF-8: <meta http-equiv="content-type" content="text/html; charset=Shift_JIS" />.

Try this instead:

open('http://www.amazon.co.jp/') {|f| Hpricot(f.read.encode("UTF-8")) }
라이센스 : CC-BY-SA ~와 함께 속성
제휴하지 않습니다 StackOverflow
scroll top