我尝试从this源
解析xml以下是我的解析代码:
while (eventType != XmlPullParser.END_DOCUMENT) {
switch (eventType) {
case XmlPullParser.START_TAG:
if (parser.getName().equals("Title")) {
current_tag = tag_title;
deal = new Deals();
}
if (parser.getName().equals("MSRP")) {
current_tag = tag_msrp;
}
if (parser.getName().equals("ConvertedCurrentPrice")) {
current_tag = tag_convertedprice;
}
if (parser.getName().equals("SavingsRate")) {
current_tag = tag_savings;
}
if (parser.getName().equals("SmallPictureURL")) {
current_tag = tag_icon;
}
break;
case XmlPullParser.END_TAG:
if (parser.getName().equals("Item")) {
current_tag = -1;
deals.add(deal);
}
break;
case XmlPullParser.TEXT:
String value = parser.getText();
switch (current_tag) {
case tag_title:
deal.setTitle(value);
break;
case tag_msrp:
deal.setMSRP(value);
break;
case tag_convertedprice:
deal.setconvertedPrice(value);
break;
case tag_savings:
deal.setSavings(value);
break;
case tag_icon:
System.out.println("Icon for the current deal is: "+value);
deal.setIcon(value);
break;
default:
break;
}
current_tag = -1;
break;
}
eventType = parser.next();
}
} catch (XmlPullParserException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
}
在第eventType = parser.next()
行,我收到以下异常:
07-19 10:43:23.262: W/System.err(922): org.xmlpull.v1.XmlPullParserException: expected: /link read: head (position:END_TAG </head>@1:427 in java.io.InputStreamReader@40dee498)
07-19 10:43:23.272: W/Trace(922): Unexpected value from nativeGetEnabledTags: 0
07-19 10:43:23.272: W/Trace(922): Unexpected value from nativeGetEnabledTags: 0
07-19 10:43:23.282: W/System.err(922): at org.kxml2.io.KXmlParser.readEndTag(KXmlParser.java:970)
07-19 10:43:23.282: W/System.err(922): at org.kxml2.io.KXmlParser.next(KXmlParser.java:372)
07-19 10:43:23.282: W/System.err(922): at org.kxml2.io.KXmlParser.next(KXmlParser.java:310)
07-19 10:43:23.282: W/System.err(922): at com.nykkos.dailydeals.Parsers.parseDeals(Parsers.java:91)
07-19 10:43:23.282: W/System.err(922): at com.nykkos.dailydeals.WebServices.downloadDeals(WebServices.java:37)
07-19 10:43:23.282: W/System.err(922): at com.nykkos.dailydeals.DealsActivity.run(DealsActivity.java:59)
我没有找到任何明显的理由说明为什么会这样。
非常感谢您解决此问题的任何帮助。
答案 0 :(得分:1)
您很可能不会尝试解析您认为的XML。相反,您似乎解析了HTML文档,该文档格式不正确。发生这种情况是因为某些HTML标记不需要结束标记,而您实际上遇到其中一个标记,如下例所示:
<head>
<link rel="stylesheet" type="text/css" href="theme.css">
</head>
因此,请确保您真正尝试解析您想要的XML。检查您尝试从中获取XML的URL。您提供的链接应该可以正常工作,但也许您的代码中有拼写错误。
另外调试代码并检查InputStream中的内容。我想里面的东西与你的期望截然不同。