- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有这个 XML:
<menu>
<day name="monday">
<meal name="BREAKFAST">
<counter name="Bread">
<dish>
<name>Plain Bagel</name>
</dish>
<counter/>
<meal/>
<day/>
<day name="tuesday">
<meal name="LUNCH">
<counter name="Other">
<dish>
<name>Cheese Bagel</name>
</dish>
<counter/>
<meal/>
<day/>
<menu/>
如果 day 标签的属性等于 monday,这就是我正在尝试做的事情。然后 meals 标签属性等于 BREAKFAST
,然后我想获取计数器的属性。 “面包”。
我已经设置了 xml pull 解析器,但我很难获得这个值。这是我尝试过的方法,现在我发现它不能也不会起作用......所以任何关于如何设置它来做到这一点的帮助都会很棒。
while (eventType != XmlResourceParser.END_DOCUMENT) {
String tagName = xmlData.getName();
switch (eventType) {
case XmlResourceParser.START_TAG:
if (tagName.equalsIgnoreCase("day")) {
if (xmlData.getAttributeValue(null, "name").equalsIgnoreCase(day)) {
if (tagName.equalsIgnoreCase("meal")) {
mealArray.add(xmlData.getAttributeValue(null, "name"));
Log.i(TAG, xmlData.getAttributeValue(null, "name"));
}
}
}
break;
case XmlResourceParser.TEXT:
break;
case XmlPullParser.END_TAG:
break;
}
eventType = xmlData.next();
}
最佳答案
您需要添加解析嵌套标签的逻辑:
一个非常简单的例子来帮助你继续前进:
我解析了这个字符串:
<menu><day name=\"monday\"><meal name=\"BREAKFAST\"><meal/><day/></menu>
代码:
try {
factory = XmlPullParserFactory.newInstance();
factory.setNamespaceAware(true);
XmlPullParser xpp = factory.newPullParser();
xpp.setInput(new StringReader("<menu><day name=\"monday\"><meal name=\"BREAKFAST\"><meal/><day/></menu>"));
int eventType = xpp.getEventType();
while (eventType != XmlResourceParser.END_DOCUMENT) {
String tagName = xpp.getName();
switch (eventType) {
case XmlResourceParser.START_TAG:
if (tagName.equalsIgnoreCase("day")) {
if (xpp.getAttributeValue(null, "name").equalsIgnoreCase("MONDAY")) {
int eventType2 = xpp.next();
while (eventType2 != XmlResourceParser.END_DOCUMENT) {
String tagName2 = xpp.getName();
switch (eventType2) {
case XmlResourceParser.START_TAG:
if (tagName2.equalsIgnoreCase("meal")) {
Log.i("tag", "meal: " + xpp.getAttributeValue(null, "name"));
}
break;
case XmlResourceParser.TEXT:
break;
case XmlPullParser.END_TAG:
break;
}
eventType2 = xpp.next();
}
}
}
break;
case XmlResourceParser.TEXT:
break;
case XmlPullParser.END_TAG:
break;
}
eventType = xpp.next();
}
} catch (XmlPullParserException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
你看出区别了吧?
基本上,我在得到我想要的那一天之后添加了这个。 (在我的例子中,硬编码字符串 "Monday"
。)
int eventType2 = xpp.next();
并基于此eventType2
, 检索到 tagName2
这将是为了“吃饭”
A better example帮助您以良好的方式编写逻辑。
希望这对您有所帮助。
关于java - XmlPullParser - 解析嵌套标记,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27415449/
在我的 XML 中,有一个带有属性的标记,该属性的名称中带有冒号: 我已经尝试了所有这些组合来尝试返回此属性的值: parser.getAttributeValue(null, "StUF:best
我正在解析的一些传入 RSS 中有一个松散的 html img 标签。意味着没有结束标记。我对传入的源的控制为零,所以我陷入了困境。无论如何我可以跳过这个标签吗?一切正常,直到我点击标签。 这是一个异
我使用 XMLPullParser 来解析 XML 文档,不幸的是,该文档包含一些特殊字符,例如: 或 &... 似乎这些字符中断了解析过程,并且仅显示这些字符之后的文本,而不显示之前的文本(如果特殊
我尝试使用以下代码读取我的应用程序创建的 XML 文件: XmlPullParser xpp = factory.newPullParser(); xpp.setInput(new StringRea
我正在使用 XMLPullParser 读取资源文件夹中的本地 XML 文件,教程的代码位于 android 开发者网站上: 链接:http://developer.android.com/refer
我正在制作一个应用程序,它将通过 xml 访问 eBay api 来搜索项目。我已按照指南 Android developer guide XMLPullParser 进行操作使用 Pull 解析器,
获取 XML 字符串的子节点的首选方法是什么? android 中似乎缺少使用 XmlPullParser 进行解析的良好示例。例如,如果我想解析这个: 81216 Lund C
我正在尝试阅读 BBC 足球 RSS。 下面是我试过的代码: URL url = new URL("http://feeds.bbci.co.uk/sport/0/football/r
我无法解决这个错误: org.xmlpull.v1.XmlPullParserException: expected: START_TAG {http://www.w3.org/2001/12/soa
我试图从我的 XML 中获取顶级元素的列表(包含重复的子元素) 示例 XML
我遇到的问题是我的应用程序接收到的 XML 数据有点损坏。因为我对此无能为力,所以我需要找到解决方法。 这是损坏部分的样子: I like cookies Do you like them too?
这是我的 xml 文件: John 1 1 Jordan 2 2 我的 Java parseXML() 方法如下
我在 XML 中有这样的东西: 2.204529 2015-12-27T12:35:45Z 我可以得到经纬度 XmlPullParser 解析器 =
我目前正在为一个 XML 文件创建一个解析器,并且一切正常,直到我添加一个额外的选项来检索链接。我有多个同名标签,我想要一个具有特定属性值的特定标签。 ... Venom 5dddd
考虑这个 XML。它描述了人员和他们拥有的汽车的列表。 Bob Toyota
我遇到了一个问题,在我的程序中,我遇到了 xmlpullparser 异常,我用眼镜检查了它,但由于我是 android 新手,我无法理解如何解决这个问题。我改了很多程序还是不行,有人帮我解决这个问题
几天以来,我在 Android 上使用 XMLPullParser 进行 XML 解析时遇到问题。我正在尝试解析这个: 我想获取图片网址,我成功了。但是,我无法检测到 END_TAG,而且我不知道该
我在 Android 中使用 XmlPullParser 解析一些文件除了文本中的一些特殊 HTML 字符外,一切正常,如下所示: í it should be í é i
我在 Android 文件系统中创建我的应用程序创建器 xml 文件。我需要使用 XmlPullParser 解析此文件,但编译时出现错误:“变量解析器可能尚未初始化”。我的代码: InputStre
我正在使用 Android 的 XmlPullParser 处理 OpenStreetMap (.osm) 文件。我遇到问题的部分是: 我需要在每个 way-
我是一名优秀的程序员,十分优秀!