此處示範基本解析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);
結果顯示:
其中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文件中提取出數據了,我們就可以把這些數據用在合適的地方,來構筑應用程序。
沒有留言:
張貼留言