在Android中解析解析本地XML文件

时间:2013-05-07 12:50:29

标签: android xml parsing xmlpullparser

我正在尝试使用pull-parsing解析本地XML的特定部分,但是,我不确定我是如何阅读这些部分的。我正在使用代码:

package com.example.xmltest;


import java.io.IOException;
import org.xmlpull.v1.XmlPullParser;
import org.xmlpull.v1.XmlPullParserException;
import android.app.Activity;
import android.content.res.Resources;
import android.content.res.XmlResourceParser;
import android.os.Bundle;
import android.widget.TextView;

public class MainActivity extends Activity {
    @Override
      public void onCreate(Bundle savedInstanceState) {
          super.onCreate(savedInstanceState);
          setContentView(R.layout.activity_main);

          TextView myXmlContent = (TextView)findViewById(R.id.xml_tv);
          String stringXmlContent;

          stringXmlContent = getAllXML();
          myXmlContent.setText(stringXmlContent);

      }

      public String getAllXML(){

          Activity activity = this;
          String str = "";

          Resources res = activity.getResources();
          XmlResourceParser xpp = res.getXml(R.xml.ensaheehint);

          try {
              xpp.next();
              int eventType = xpp.getEventType();
              System.out.println("eventType : " + eventType);
              while (eventType != XmlPullParser.END_DOCUMENT)
              {
                   if(eventType == XmlPullParser.START_DOCUMENT){
                       str += "nXML Parsing Starting...n";
                   }
                   else if(eventType == XmlPullParser.START_TAG)
                   {

                       eventType = xpp.next();
                       if(eventType == XmlPullParser.TEXT){
                           String text = xpp.getName(); 
                           str +=  "**TEXT: "+text;
                       }


                   }
                   else if(eventType == XmlPullParser.END_TAG)
                   {
                       str += "nending tag: "+xpp.getName();
                   }
                   else if(eventType == XmlPullParser.TEXT)
                   {
                       str += "nvalue : "+xpp.getText();
                   }
                   eventType = xpp.next();
              }
               str += "nnXML parsing Ending......";

        } catch (XmlPullParserException e) {
              e.printStackTrace();
        } catch (IOException e) {
              e.printStackTrace();
        }
        return str;
    }

  }

以下是我的XML文件: 我正在尝试一次访问位于aya中的一个文本字符串。

<quran>
<sura index="1" name="الفاتحة">
    <aya index="1" text="In the name of Allah, the Entirely Merciful, the Especially Merciful."/>
    <aya index="2" text="[All] praise is [due] to Allah, Lord of the worlds -"/>
    <aya index="3" text="The Entirely Merciful, the Especially Merciful,"/>
    <aya index="4" text="Sovereign of the Day of Recompense."/>
    <aya index="5" text="It is You we worship and You we ask for help."/>
    <aya index="6" text="Guide us to the straight path -"/>
    <aya index="7" text="The path of those upon whom You have bestowed favor, not of those who have evoked [Your] anger or of those who are astray."/>
</sura>

1 个答案:

答案 0 :(得分:0)

如果我理解正确,这里的问题是你的XML没有任何价值。但是,您确实有一些带有属性的标签。

前:

<aya index="6" text="Guide us to the straight path -"/>

与:

不同
<aya index="6">Guide us to the straight path -"</aya>

这两个中的后一个可能适用于您的代码。我认为你想要的是阅读属性text而不是标签的值。

您可以找到有关如何获取属性here的更多信息。

希望它有所帮助。