【问题标题】:XML parser having issuesXML 解析器有问题
【发布时间】:2017-04-26 12:40:07
【问题描述】:

我一直在尝试解析一个看起来像这样的 xml。这种正确的xml格式是如何解析它的。我想知道xml的格式是什么。

<string xmlns="http://schemas.microsoft.com/2003/10/Serialization/">1|3|195,317,65,108|342,227,66,99|280,98,84,112</string>

和我的 xml 解析器活动 是

public class RetrieveFeed extends AsyncTask {

URL url;
ArrayList<String> headlines = new ArrayList();
ArrayList<String> links = new ArrayList();
@Override
protected Object doInBackground(Object[] objects) {
    // Initializing instance variables


    try {
        url = new URL("http://54.179.134.139/viViewapi/api/values");

        XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
        factory.setNamespaceAware(false);
        XmlPullParser xpp = factory.newPullParser();

        // We will get the XML from an input stream
        xpp.setInput(getInputStream(url), "UTF_8");


        boolean insideItem = false;

        // Returns the type of current event: START_TAG, END_TAG, etc..
        int eventType = xpp.getEventType();
        while (eventType != XmlPullParser.END_DOCUMENT) {
            if (eventType == XmlPullParser.START_TAG) {

                if (xpp.getName().equalsIgnoreCase("html")) {
                    insideItem = true;
                } else if (xpp.getName().equalsIgnoreCase("pre")) {
                    if (insideItem)
                        headlines.add(xpp.nextText()); //extract the headline
                }
                /*else if (xpp.getName().equalsIgnoreCase("link")) {
                    if (insideItem)
                        links.add(xpp.nextText()); //extract the link of article
                }*/
            } else if (eventType == XmlPullParser.END_TAG && xpp.getName().equalsIgnoreCase("html")) {
                insideItem = false;
            }

            eventType = xpp.next(); //move to next element
        }

    } catch (MalformedURLException e) {
        e.printStackTrace();
    } catch (XmlPullParserException e) {
        e.printStackTrace();
    } catch (IOException e) {
        e.printStackTrace();
    }

    return headlines;
}


public InputStream getInputStream(URL url) {
    try {
        return url.openConnection().getInputStream();
    } catch (IOException e) {
        return null;
    }
}

public ArrayList<String> heads()
{
    return headlines;
}

}

我不知道这种做法是对是错

【问题讨论】:

  • 你的标题说你有问题,但你没有说问题是什么。您的问题正文说“我想知道 xml 的格式是什么”,但这对于 SO 来说是一个完全不合适的问题 - 有很多参考资料可以解释 XML 的格式。

标签: xml android-xml android-xmlpullparser


【解决方案1】:

像 JSON 这样的 XML 至少需要一个根元素。在您的示例中,您 do 有一个名为“string”的根元素,所以这里没有问题。

查看此XML Syntax Guide 以获取快速 XML 教程。请注意,可以使用“字符串”,因为它不是保留字(请参阅XML Reserved Words)。

您发布的 XML sn-p 是有效的 XML。您可以使用此XML Validator 验证 XML。

你不一定需要xmlns property(命名空间),所以它可以变成:

<string>1|3|195,317,65,108|342,227,66,99|280,98,84,112</string>

这个 XML 只是描述一个字符串。如果你想用字符串属性来描述一个对象,你会得到类似 XML 的东西:

<root>
  <string>1|3|195,317,65,108|342,227,66,99|280,98,84,112</string>
</root>

如果您想了解有关从 XML 读取值的更多信息,请查看之前的 simple xml parsing Stack Overflow 答案。

【讨论】:

    猜你喜欢
    • 2012-03-23
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2012-08-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多