- 535 名前:デフォルトの名無しさん mailto:sage [2008/11/24(月) 01:41:41 ]
- ちょっと前に、WWW::Mechanizeを1.34から1.50にupしたんですが、この1.50の挙動についての質問です。
1.50になってから、$mech->get('example.com/')なんかでgetsしてきたページの内容を $mech->content()で書き出すと、utf8フラグ付の文字列に自動でdecodeされたものが出力されます。 ($mech->response->contentでは、そのまま変換なしで返ってきます。) さらにこの状態で、$mech->find_linksやfind_images,$mech->form->inputsなどの戻り値オブジェクトから $_->textや$_->valueなども、utf8_decodeされたものが返ってくるようになりました。 これはこれで、戻り値を正規表現等で検知するのに便利になった部分もあるのですが、 今少しばかり困ったことになっております。 実は、とあるサイトをクロールしていて、そのページ自体はsjisで書いてあるのですが、 ページのheaderに、<meta http-equiv="content-type" content="EUC-JP">とかの記述があって、 どうもこの記述を鵜呑みにして、元の文字列をEUC-JPとしてdecodeをしてしまって、化けバケになりました。
|

|