2012-09-10 148 views
0

我想解析一個xml文件(來自資產),但是我無法正確理解它。用Android中的屬性解析XML

通常當我做到這一點,我會格式化像下面的我的XML文件:

<channel> 
    <item> 
    <name>Hello Earth</name> 
    <place>Earth</place> 
    </item> 
    <item> 
    <name>Goodbye Mars</name> 
    <place>Mars</place> 
    </item/> 
</channel> 

而且我會用下面的代碼分析出什麼,我需要:

AssetManager assetManager = getAssets(); 
InputStream inputStream = assetManager.open("words.xml"); 

DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); 
factory.setCoalescing(true); 
DocumentBuilder builder = factory.newDocumentBuilder(); 

Document dom = builder.parse(inputStream);  

org.w3c.dom.Element root = dom.getDocumentElement(); 
NodeList items = root.getElementsByTagName("item");  

String name=""; 
String place=""; 

for (int i = 0; i < items.getLength(); i++) { 
Node item = items.item(i); 
NodeList properties = item.getChildNodes(); 

for (int j = 0; j < properties.getLength(); j++) { 
    Node property = properties.item(j); 
    String propertyName = property.getNodeName(); 

    if (propertyName.equalsIgnoreCase("name")) { 
     String strText = property.getFirstChild() 
     .getNodeValue(); 
     nam = strText; 
    } 

    if (propertyName.equalsIgnoreCase("place")) { 
     String strText = property.getFirstChild() 
     .getNodeValue(); 
     place = strText; 
    } 

    db.insertWord(name, place); 
} 

然而, xml來自另一個源,它的格式不同,它使用屬性,因爲它是一個mysql導出。這是我必須解析XML,但我無法弄清楚如何,我應該這樣,我試着用的getAttribute玩弄()方法,但不能獲取數據了XML的:

<table name="item"> 
    <column name="name">Hello Earth</column> 
    <column name="place">Earth</column> 
</table> 
<table name="item"> 
    <column name="name">Goodbye Mars</column> 
    <column name="place">Mars</column> 
</table> 

回答

1

你可以試試這個使用拉解析器遵循..

//定義類項目

class Item 
{ 
    String name; 
    String place; 
} 



ArrayList<Item>items=new ArrayList<Item>(); 




void somemethod() 
{ 

AssetManager assetManager = getAssets(); 
InputStream inputStream = assetManager.open("words.xml"); 

Item item=new Item(); 
try 
     { 
      XmlPullParserFactory factory = XmlPullParserFactory.newInstance(); 
      factory.setNamespaceAware(true); 
      XmlPullParser xpp = factory.newPullParser(); 
      xpp.setInput(inputStream,null); 
      int eventType = xpp.getEventType(); 
      while (eventType != XmlPullParser.END_DOCUMENT) 
      { 
       if(eventType == XmlPullParser.START_DOCUMENT) 
        { }     
       else if(eventType == XmlPullParser.START_TAG) 
       { 
        try 
        {       
          if(xpp.getName()!=null&& xpp.getName().equalsIgnoreCase("name")) 
           { 
            eventType = xpp.next(); 
            item.name=Integer.parseInt(xpp.getText().toString()); 
           } 
          else if(xpp.getName()!=null&& xpp.getName().equalsIgnoreCase("place")) 
           { 
            eventType = xpp.next(); 
            item.place=xpp.getText().toString(); 
           }      
         } 
        catch (Exception e) 
         { 
          //e.printStackTrace(); 
         } 
       } 
       else if(eventType == XmlPullParser.END_TAG) 
       { 
        if(xpp.getName()!=null&& xpp.getName().equalsIgnoreCase("content")) 
         { 
          eventType = xpp.next(); 
          items.put(item); 
          item=new Item(); 
         } 
       } 
       else if(eventType == XmlPullParser.TEXT) 
       {} 
       eventType = xpp.next();  
     }// end of while      

     } 
     catch (XmlPullParserException e) 
     { 
      //e.printStackTrace(); 
     } 
     catch (IOException e) 
     { 
      //e.printStackTrace(); 
     } 
     finally 
     { 
      try 
      { 
       if(inputStream!=null) 
        inputStream.close(); 
      } catch (IOException e) 
      {    
      } 
     } 


    } 
+0

謝謝你,這真的幫助我 – brux

1

嘗試這些.... ..

1.DOM PARSER

2.SAX PARSER

3.JAXB AND JAXP

4.CASTOR

5.Pull Parser