此處示範基本解析XML單項解析方式

當然接下來可以用自己的方式來遍歷解析

 

 

yahoo weather api

https://weather.yahooapis.com/forecastrss?w=2306179

<item>

<title>Conditions for Taipei City, TW at 11:29 pm CST</title>

<geo:lat>25.09</geo:lat>

<geo:long>121.56</geo:long>

<link>

http://us.rd.yahoo.com/dailynews/rss/weather/Taipei_City__TW/*http://weather.yahoo.com/forecast/TWXX0021_f.html

</link>

<pubDate>Sat, 17 May 2014 11:29 pm CST</pubDate>

<yweather:condition text="Mostly Cloudy" code="27" temp="81" date="Sat, 17 May 2014 11:29 pm CST"/>

<description>

<![CDATA[

<img src="http://l.yimg.com/a/i/us/we/52/27.gif"/><br /> <b>Current Conditions:</b><br /> Mostly Cloudy, 81 F<BR /> <BR /><b>Forecast:</b><BR /> Sat - Partly Cloudy. High: 86 Low: 77<br /> Sun - PM Thundershowers. High: 86 Low: 75<br /> Mon - Thunderstorms. High: 82 Low: 75<br /> Tue - Thunderstorms. High: 87 Low: 74<br /> Wed - Rain. High: 80 Low: 74<br /> <br /> <a href="http://us.rd.yahoo.com/dailynews/rss/weather/Taipei_City__TW/*http://weather.yahoo.com/forecast/TWXX0021_f.html">Full Forecast at Yahoo! Weather</a><BR/><BR/> (provided by <a href="http://www.weather.com" >The Weather Channel</a>)<br/>

]]>

</description>

<yweather:forecast day="Sat" date="17 May 2014" low="77" high="86" text="Partly Cloudy" code="29"/>

<yweather:forecast day="Sun" date="18 May 2014" low="75" high="86" text="PM Thundershowers" code="39"/>

<yweather:forecast day="Mon" date="19 May 2014" low="75" high="82" text="Thunderstorms" code="4"/>

<yweather:forecast day="Tue" date="20 May 2014" low="74" high="87" text="Thunderstorms" code="4"/>

<yweather:forecast day="Wed" date="21 May 2014" low="74" high="80" text="Rain" code="12"/>

<guid isPermaLink="false">TWXX0021_2014_05_21_7_00_CST</guid>

</item>

---------------------------------------

 

 

                   //使用DOM解析XML
                     DocumentBuilderFactory dfactory=DocumentBuilderFactory.newInstance();
                     DocumentBuilder builder = dfactory.newDocumentBuilder();
                     Document doc = builder.parse(new InputSource(new StringReader(getxml)));
                      
                     //doc.getDocumentElement().normalize();
                     //先get到你要的tag吧,記得回傳型態是NodeList,
                     NodeList Node1=doc.getElementsByTagName("yweather:location");
                     NodeList Node2=doc.getElementsByTagName("yweather:forecast");
                     NodeList Node_item=doc.getElementsByTagName("item");
                     String value1=Node1.item(0).getAttributes().item(0).getNodeValue();
                     String value2=Node1.item(0).getAttributes().item(2).getNodeValue();
                     String value3=Node2.item(1).getAttributes().item(3).getNodeValue();
                     String value4=Node2.item(2).getAttributes().item(3).getNodeValue();
                     String v_item=Node_item.item(0).getChildNodes().item(1).getFirstChild().getNodeName();


                     //需注意的是選了節點 getChildNodes().item(1)後還需要加.getFirstChild()才行

                     String v_item2=Node_item.item(0).getFirstChild().getNodeValue();
                    
                     System.out.println("value"+value1);
                     tv1.setText(value1+value2+"value3  "+value3+"value4  "+value4+"v_item  "+v_item+"value6  "+v_item2);

結果顯示:

image

 

其中getFirstChilid的問題可參考網址:

http://www.ogshoppingmall.com/list.asp?id=48665

其中一段:.

當一個Node對象被建立之后,保存在XML文檔中的數據就被提取出來并封裝在這個Node中了。在這個例子中,要提取Message標簽內的內容,我們通常會使用Node對象的getNodeValue()方法:
String message = my_node.getFirstChild().getNodeValue();
請注意,這里還使用了一個getFirstChild()方法來獲得message下面的第一個子Node對象。雖然在message標簽下面除了文本外并沒有其它子標簽或者屬性,但是我們堅持在這里使用getFirseChild()方法,這主要和W3C對DOM的定義有關。W3C把標簽內的文本部分也定義成一個Node,所以先要得到代表文本的那個Node,我們才能夠使用getNodeValue()來獲取文本的內容。現在,既然我們已經能夠從XML文件中提取出數據了,我們就可以把這些數據用在合適的地方,來構筑應用程序。

arrow
arrow
    文章標籤
    Xml解析
    全站熱搜

    changcc929 發表在 痞客邦 留言(0) 人氣()