2011年5月19日木曜日

[Java]RSSを読み込んで表示するプログラムをさっくり作る

すごーく前のエントリで「bot」をつくってます☆
とかいたとおもいますが、かなり進んでいません。
というのも、DBを扱わないといけなくて、そこで躓いているんですが。
まー、それもよくないなと思って、とりあえずできることからはじめてみます。
Yahoo!天気情報でRSSが提供されているのでそこから天気情報を取り込むプログラムをつくることにしました。
Yahoo!天気情報提供RSSについてはこちら

ではさっそくJavaでさくさくと。
東京都の天気を読み込むものをつくってみました。

まずは面倒なのでRSSのアドレスを定義します。

  1. private static final String RSS_URL= "http://rss.weather.yahoo.co.jp/rss/days/13.xml";  

続いてDocumentにRSSの情報をパースします。

  1. DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();  
  2.     
  3.    DocumentBuilder builder = factory.newDocumentBuilder();  
  4.      
  5.    Document document = builder.parse(RSS_URL);  

読み込んだXMLに対して要素を抜き出していく感じですね。
いきなり飛び越しで読み込めないので
順番を追って読み出します。
個人的には"title"と"description"が必要なのでそちらだけを読み込みます。

  1. // ドキュメントのルートを取得  
  2.    Element root = document.getDocumentElement();  
  3.      
  4.    // ルート直下の"channel"に含まれるノードリストを取得  
  5.    NodeList channel = root.getElementsByTagName("channel");  
  6.      
  7.    // "channel"直下の"title"に含まれるノードリストを取得  
  8.    NodeList title = ((Element)channel.item(0)).getElementsByTagName("title");  
  9.      
  10.    // とりあえず出力する  
  11.    System.out.println("タイトル:" + title.item(0).getFirstChild().getNodeValue());  
  12.      
  13.    // 各"item"とその中の"title"と<description>を取得する。       
  14.    NodeList item_list = root.getElementsByTagName("item");  
  15.      
  16.    // item分ループする  
  17.    for(int i = 0; i < item_list.getLength(); i++) {  
  18.       
  19.     Element element = (Element)item_list.item(i);  
  20.   
  21.     // title を取得する  
  22.                 NodeList item_title = element.getElementsByTagName("title");  
  23.                 // description を取得する  
  24.                 NodeList item_description = element.getElementsByTagName("description");  
  25.   
  26.                 // 出力する  
  27.                 System.out.println(item_title.item(0).getFirstChild().getNodeValue());  
  28.                 System.out.println(item_description.item(0).getFirstChild().getNodeValue());  
  29.                   
  30.    }  
  31. </description>  
もちろん、try-catchで囲まないといけないので実際のソースはこうなります。
  1. import java.io.IOException;  
  2.   
  3. import javax.xml.parsers.DocumentBuilder;  
  4. import javax.xml.parsers.DocumentBuilderFactory;  
  5. import javax.xml.parsers.ParserConfigurationException;  
  6.   
  7. import org.w3c.dom.Document;  
  8. import org.w3c.dom.Element;  
  9. import org.w3c.dom.NodeList;  
  10. import org.xml.sax.SAXException;  
  11.   
  12.   
  13. public class RSS_Test {  
  14.   
  15.  private static final String RSS_URL= "http://rss.weather.yahoo.co.jp/rss/days/13.xml";  
  16.    
  17.  public static void main(String[] args) {  
  18.     
  19.   try {  
  20.      
  21.    DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();  
  22.     
  23.    DocumentBuilder builder = factory.newDocumentBuilder();  
  24.      
  25.    Document document = builder.parse(RSS_URL);  
  26.      
  27.    // ドキュメントのルートを取得  
  28.    Element root = document.getDocumentElement();  
  29.      
  30.    // ルート直下の"channel"に含まれるノードリストを取得  
  31.    NodeList channel = root.getElementsByTagName("channel");  
  32.      
  33.    // "channel"直下の"title"に含まれるノードリストを取得  
  34.    NodeList title = ((Element)channel.item(0)).getElementsByTagName("title");  
  35.      
  36.    // とりあえず出力する  
  37.    System.out.println("タイトル:" + title.item(0).getFirstChild().getNodeValue());  
  38.      
  39.    // 各"item"とその中の"title"と"description"を取得する。       
  40.    NodeList item_list = root.getElementsByTagName("item");  
  41.      
  42.    // item分ループする  
  43.    for(int i = 0; i < item_list.getLength(); i++) {  
  44.       
  45.     Element element = (Element)item_list.item(i);  
  46.   
  47.     // title を取得する  
  48.                 NodeList item_title = element.getElementsByTagName("title");  
  49.                 // description を取得する  
  50.                 NodeList item_description = element.getElementsByTagName("description");  
  51.   
  52.                 // 出力する  
  53.                 System.out.println(item_title.item(0).getFirstChild().getNodeValue());  
  54.                 System.out.println(item_description.item(0).getFirstChild().getNodeValue());  
  55.                   
  56.    }  
  57.      
  58.      
  59.   } catch (ParserConfigurationException e) {  
  60.    e.printStackTrace();  
  61.   } catch (SAXException e) {  
  62.    e.printStackTrace();  
  63.   } catch (IOException e) {  
  64.    e.printStackTrace();  
  65.   }  
  66.     
  67.  }  
  68.   
  69. }  
で、取得したデータはこんな感じになります。
タイトル:Yahoo!天気情報 - 東京都の天気
【 19日(木) 東京(東京) 】 晴時々曇 - 24℃/16℃ - Yahoo!天気情報
晴時々曇 - 24℃/16℃
【 19日(木) 伊豆諸島北部(大島) 】 晴れ - 23℃/15℃ - Yahoo!天気情報
晴れ - 23℃/15℃
【 19日(木) 伊豆諸島南部(八丈島) 】 晴時々曇 - 23℃/16℃ - Yahoo!天気情報
晴時々曇 - 23℃/16℃
【 19日(木) 小笠原諸島(父島) 】 曇後雨 - 24℃/22℃ - Yahoo!天気情報
曇後雨 - 24℃/22℃
[PR] 「東日本大震災」に関する情報
「東日本大震災」に関する情報

[PR]ってなんだろ・・・(汗)
とりあえず、こんな感じで。

0 件のコメント:

コメントを投稿