2009年12月05日 過去Blog
phpでrssの情報を抜き出したい場合は、titleやlinkの要素は以下の通りで抜き出せます。
<?php // Load and parse the XML document
$rss =  simplexml_load_file('http://partners.userland.com/nytRss/nytHomepage.xml');
$title =  $rss->channel->title;
?>
<html xml:lang=”en” lang=”en”> <head> <title><?php echo $title; ?></title> </head> <body> <h1><?php echo $title; ?></h1> <?php // Here we’ll put a loop to include each item’s title and description foreach ($rss->channel->item as $item) { echo “<h2><a href='” . $item->link . “‘>” . $item->title . “</a></h2>”; echo “<p>” . $item->description . “</p>”; } ?> </body> </html> 最初に書いた通り、上記でtitleなどは取得出来ますが、<content:encoded>など、
<![CDATA[
が含まれる箇所が取得できません。 そこで、「MagpieRSS – PHP で使える RSS パーサー。」を参考にMagpieRSSというものを利用しました。

使い方

index.php に http://yamazon.org/feed のRSSを埋め込むとして手順を示します。
  • http://magpierss.sourceforge.net/ で MagpieRSS (magpierss-0.3.tar.gz) を入手。
  • magpierss-0.3.tar.gz を解凍。
  • 拡張子が .inc のファイルと extlib フォルダを index.php と同じディレクトリにアップロード。
  • 同じディレクトリ(サーバ上)の下に cache という名前のディレクトリを作る。
  • index.php の中のヘッドラインを埋め込みたい位置に以下のコードを挿入。
以上の設定が完了したら、以下のようなソースで抜き出します。
<?php
include('rss_fetch.inc');

$url = "http://yamazon.org/feed";
$rss = fetch_rss($url);

if($rss){
$items = $rss->items;
foreach($items as $item){
$content = $item["content"]["encoded"];
$content = mb_convert_encoding($content, "UTF-8", "auto");
echo $content;
}
}else{
echo "file not found.";
}
?>
これで、<content:encoded>が抜き出せましたが、文字化けしてしまいました。 mb_convert_encodingでエンコードしても文字化けのまま・・・。(どうやらASCIIに変換されている模様?) 文字化けについては解決次第、報告しようと思います。

<追記>

文字化けの件が解決したのでメモしておきます。

(Jcode.phpを使う方法 – mb_convert_encodingが使えない場合の解決法その1)

  • http://www.spencernetwork.org/jcode/ でJcode.php(jcode_1.34.zip)を入手。
  • jcode_1.34.zip を解凍。
  • jcode.phps を jcode.php に拡張子を変えた後、readme.txt 以外のファイルを同じディレクトリにアップロード。(jcode.php と code_table.ucs2jis のみでも可)
  • コードを以下の様に変更。
 <?php
//MagpieRSS
 include('rss_fetch.inc');
 require_once 'code_table.ucs2jis';
 require_once 'jcode.php';

 $url = $search_domain;
 $rss = fetch_rss($url);

 $title = $rss->channel["title"];
 //JcodeConvert($str, $from, $to) 0:PASS(無変換)1:EUC-JP 2:Shift_JIS 3:ISO-2022-JP(JIS) 4:UTF-8
 //今回は変換元がEUC-JPだったので、PASS,4 でUTF-8に変換してます。
 $title = JcodeConvert($title, 0, 4);

 echo $title;

 if($rss){
 $items = $rss->items;
 foreach($items as $item){
 $content = $item["content"]["encoded"];
 $url   = $item["link"];

 $content = JcodeConvert($content, 0, 4);
 echo $url;
 echo $content;

 }
 }else{
 echo "file not found.";
 }
//MagpieRSS
 ?>
私の場合は以上で、文字化けもなく <![CDATA[ が含まれる要素も全て取得出来ました。 RSSを取得する、その他の方法として

XML::FeedPPで、content:encodedなどを取得する方法

などもあるようです。
//JcodeConvert($str, $from, $to) 0:PASS(無変換)1:EUC-JP 2:Shift_JIS 3:ISO-2022-JP(JIS) 4:UTF-8
http://www.doyouphp.jp/php5/php5_simplexml.shtml

この投稿へのコメント

コメントはまだありません。

コメントを残す

メールアドレスが公開されることはありません。

次のHTML タグと属性が使えます。
<a href="" title=""> <abbr title=""> <acronym title=""> <b> <blockquote cite=""> <cite> <code> <del datetime=""> <em> <i> <q cite=""> <strike> <strong>

CAPTCHA


ピックアップ記事

オーガナイザーからProvisioningする際にエラー

2010年12月23日 過去Blog
新しく購入したipadをオーガナイザーから、Provisioningしようとすると以下のようなエラーが出ました。 An unexpected error occurred. Please try again. If the problem persists, please contact Apple Developer Support. mac上のXCodeがiOS4.1のバージョンだったため、…
「オーガナイザーからProvisioningする際にエラー」をはてなブックマークに追加

iPhone CoreLocation で位置情報、方位情報の取得

2011年04月28日 過去Blog
http://www.bright-sys.co.jp/blog/iphone-corelocation-1/ http://www.bright-sys.co.jp/blog/iphone-corelocation-2/ divorce lawyers san diego…
「iPhone CoreLocation で位置情報、方位情報の取得」をはてなブックマークに追加

Word Pressの自動アップグレードに失敗する

2011年01月12日 過去Blog
ルートディレクトリが見つかりません ディレクトリが見つからない関連のエラーは以下のように、「wp-config.php」に追加すれば、直るようです。 参考:「wp-config.php_の編集」 define('FTP_BASE', '/path/to/wordpress/'); define('FTP_CONTENT_DIR', '/path/to/wordpress/wp-content/'…
「Word Pressの自動アップグレードに失敗する」をはてなブックマークに追加

phpで処理を遅延させてから実行する。

2009年12月26日 過去Blog
phpで少し時間をおいてから処理を実行したい場合は、sleepを使います。 例) [php]<?php echo "最初の処理"; //3秒後に実行 sleep(3); //処理再開 echo "遅延後の処理"; ?>[/php]
「phpで処理を遅延させてから実行する。」をはてなブックマークに追加

サーバの時刻調整

2010年03月05日 過去Blog
サーバの時刻設定 1. 時刻確認 date 2. 時刻設定 date -s "2006/02/20 19:03" linux上で、上記のコマンドを実行すれば、調整出来ます。 参照元:http://memorva.jp/memo/linux/date_ntp.php buy anabolics online…
「サーバの時刻調整」をはてなブックマークに追加
© graffiti on the web . All rights reserved. WordPress Theme by comfy