gpt4 book ai didi

java - XmlPullParser 解析内部标记

转载 作者:行者123 更新时间:2023-11-29 21:20:13 29 4
gpt4 key购买 nike

这是我的 xml 文件:

    <name>John</name>
<currency>
<euro>1</euro>
<dollar>1</dollar>
</currency>
<name>Jordan</name>
<currency>
<euro>2</euro>
<dollar>2</dollar>
</currency>

我的 Java parseXML() 方法如下所示:

public void parseXML() throws XmlPullParserException, IOException,
NullPointerException {
XmlPullParserFactory factory = XmlPullParserFactory.newInstance();
factory.setNamespaceAware(true);
XmlPullParser xpp = factory.newPullParser();
File file = new File("in.xml");

FileInputStream fis = new FileInputStream(file);
xpp.setInput(new InputStreamReader(fis));

int eventType = xpp.getEventType();
while (eventType != XmlPullParser.END_DOCUMENT) {
if (eventType == XmlPullParser.START_TAG) {

String tag = xpp.getName();

Currency c = new Currency();
if (tag.equals("euro")) {
eventType = xpp.next();
c.setEuro(Integer.parseInt(xpp.getText()));

}
if (tag.equals("dollar")) {
eventType = xpp.next();
c.setDollar(Integer.parseInt(xpp.getText()));
}

if (tag.equals("name")) {
eventType = xpp.next();
nameList.add(xpp.getText());

}

如何解析 currency 标签内的 eurodollar 标签?我不知道该怎么做。谁能帮我解决这个问题?我在谷歌中寻找它,但没有得到我的解决方案。

最佳答案

您可能想看一下 XML pull parser tutorial在 Android 开发者网站上。以下是根据该教程改编的解决方案的部分概述。

首先创建一个遍历文档并查找您感兴趣的顶级标签的方法:

private void readDocument(XmlPullParser parser) throws XmlPullParserException, IOException {
while (parser.next() != XmlPullParser.END_TAG) {
if (parser.getEventType() != XmlPullParser.START_TAG) {
continue;
}
String name = parser.getName();
if (name.equals("name")) {
readName(parser);
} else if (name.equals("currency"))
readCurrency(parser);
else {
skip(parser);
}
}
}

然后用自己的方法处理每个标签,必要时重复该过程:

private void readCurrency(XmlPullParser parser) throws XmlPullParserException, IOException {
parser.require(XmlPullParser.START_TAG, ns, "currency");
while (parser.next() != XmlPullParser.END_TAG) {
if (parser.getEventType() != XmlPullParser.START_TAG) {
continue;
}
String name = parser.getName();
if (name.equals("euro")) {
euro = readEuro(parser);
} else if (name.equals("dollar")) {
dollar = readDollar(parser);
} else {
skip(parser);
}
}
}

// Read in the content of the Euro element.
private String readEuro(XmlPullParser parser) {
return readText(parser);
}

我省略了教程中详细介绍的 skip()readText() 方法,您显然还想添加代码来存储您以某种方式读取的数据。但希望这能让您了解如何构建解析器来处理嵌套元素。

关于java - XmlPullParser 解析内部标记,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20818056/

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com