Android XML解析在第一个孩子停止了

时间:2014-02-11 20:59:36

标签: android xml xmlpullparser

我正在尝试解析这样的XML文件:

<?xml version="1.0" encoding="UTF-8" standalone="yes"?>
<cartoonia xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance">
    <stagione nome="Cartoonia Speciale due per vedere se funziona">
        <puntata>
            <numero>0</numero>
            <titolo>Ciao Cipo</titolo>
            <link>http://www.dimaleinpentium.com/app/download/5429764359/Cartoonia+%288%5E+Puntata%29.mp3?t=1389213968</link>
            <descrizione>Ma ciao mia bella Cipo</descrizione>
        </puntata>
    </stagione> 
    <stagione nome="Stagione 1">
        <puntata>
            <numero>1</numero>
            <titolo>Puntata 1</titolo>
            <link>http://www.dimaleinpentium.com/app/download/5424302459/Cartoonia+1%5E+Puntata.mp3?t=1383736417</link>
            <descrizione>Descrizione</descrizione>
        </puntata>
        <puntata>
            <numero>2</numero>
            <titolo>Puntata 2</titolo>
            <link>http://www.dimaleinpentium.com/app/download/5425828359/Cartoonia+%282%5E+Puntata%29.mp3?t=1384351442</link>
            <descrizione>Descrizione</descrizione>
        </puntata>
        <puntata>
            <numero>3</numero>
            <titolo>Puntata 3</titolo>
            <link>http://www.dimaleinpentium.com/app/download/5427087659/Cartoonia+%283%5E+Puntata%29.mp3?t=1384981673</link>
            <descrizione>Descrizione Puntata</descrizione>
        </puntata>
    </stagione>
    <stagione nome="Cartoonia Special!">
        <puntata>
            <numero>0</numero>
            <titolo>Ciao Cipo</titolo>
            <link>http://www.dimaleinpentium.com/app/download/5429764359/Cartoonia+%288%5E+Puntata%29.mp3?t=1389213968</link>
            <descrizione>Ma ciao mia bella Cipo</descrizione>
        </puntata>
    </stagione> 
</cartoonia>

使用此代码(取自AndroidDevs并修改为适合我的文件)我只能先阅读<stagione>,其他人会被忽略。

public Map < String, List < Entry >> parse(InputStream in ) throws XmlPullParserException, IOException {
    try {
        XmlPullParser parser = Xml.newPullParser();
        parser.setFeature(XmlPullParser.FEATURE_PROCESS_NAMESPACES, false);
        parser.setInput( in , null);
        parser.nextTag();
        return readFeed(parser);
    } finally { in .close();
    }
}


private Map < String, List < Entry >> readFeed(XmlPullParser parser) throws XmlPullParserException, IOException {
    Map < String, List < Entry >> entries = new HashMap < String, List < Entry >> ();
    String index = "";
    parser.require(XmlPullParser.START_TAG, ns, "cartoonia");
    while (parser.next() != XmlPullParser.END_TAG) {
        Log.d(TAG, "> " + parser.getLineNumber() + " <");
        if (parser.getEventType() != XmlPullParser.START_TAG) {
            continue;
        }
        String name = parser.getName();
        Log.d(TAG, "" + name);

        if (name.equals("stagione")) {
            index = parser.getAttributeValue(null, "nome");
            Log.d(TAG, "    " + index);
            entries.put(index, new ArrayList < Entry > ());
        } else if (name.equals("puntata")) {
            Log.d(TAG, "        Entry: " + parser.getName());
            List < Entry > en = entries.get(index);
            en.add(readEntry(parser));
        } else {
            skip(parser);
        }
    }
    return entries;
}

// Parses the contents of an entry. If it encounters a title, summary, or link tag, hands them off
// to their respective "read" methods for processing. Otherwise, skips the tag.
private Entry readEntry(XmlPullParser parser) throws XmlPullParserException, IOException {
    parser.require(XmlPullParser.START_TAG, ns, "puntata");
    String title = null;
    String summary = null;
    String link = null;
    String number = null;

    while (parser.next() != XmlPullParser.END_TAG) {
        if (parser.getEventType() != XmlPullParser.START_TAG) {
            continue;
        }
        String name = parser.getName();
        if (name.equals("titolo")) {
            title = readTitle(parser);
        } else if (name.equals("numero")) {
            number = readNumber(parser);
        } else if (name.equals("descrizione")) {
            summary = readSummary(parser);
        } else if (name.equals("link")) {
            link = readLink(parser);
        } else {
            skip(parser);
        }
    }
    return new Entry(title, number, summary, link);
}

不显示任何错误或警告或例外。如果我更改<stagione>的顺序,我会得到相同的结果,所以我不认为这是文件的问题。

2 个答案:

答案 0 :(得分:1)

实际上,我在这里无法理解,它看起来像你在想“stagione”和“puntata”是邻居标签,但它们不是邻居,“puntata”是“stagione”的元素,所以,你需要在每个“stagione”中创建另一个解析器来读取“puntata”的

if (name.equals("stagione")) {
            index = parser.getAttributeValue(null, "nome");
            Log.d(TAG, "    " + index);
            entries.put(index, new ArrayList < Entry > ());
        } else if (name.equals("puntata")) {
            Log.d(TAG, "        Entry: " + parser.getName());
            List < Entry > en = entries.get(index);
            en.add(readEntry(parser));
        }

答案 1 :(得分:1)

问题在于你的循环条件:

while (parser.next() != XmlPullParser.END_TAG) { ...

您将END_TAGEND_DOCUMENT混为一谈。我正在为您添加一个适合您实现的示例。我尽可能多地添加了评论。看看这个:

int eventType;

while ((eventType = parser.getEventType()) != XmlPullParser.END_DOCUMENT) {
  String current_tag = null;
  switch (eventType) {
    case XmlPullParser.START_DOCUMENT:
      // Do the pertinent initializations here (if you need, if not, just break)
      break;

    case XmlPullParser.START_TAG:
      current_tag = parser.getName();               // Get current tag
      if (current_tag.equals("cartoonia")
        continue;
      else if (current_tag.equals("stagione"))      // Initialize a new object to store a "stagione", probably add the name from "nome"
        myStagione = new WhatEver(); 
      else if (current_tag.equals("puntata"))       // Do the proper initialization to store a "puntata"
        myPuntata = new WhatEver2(); 
      else if (myPuntata != null) {                 // Just do the same!
        ...
      }

      break;

    case XmlPullParser.END_TAG:                     // This is called if you terminated processing a tag, not at the end of the XML file!
      current_tag = parser.getName();
      ...

      break;
    }

  eventType = parser.next();                        // Next event
}