那是我的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());
}
如何解析标签euro
和dollar
内部currency
标签?我不知道该怎么做。任何人都可以帮助我解决这个问题吗?我在Google中寻找它,但没有得到我的解决方案。
您可能想看一下Android Developers网站上的XML Pull Parser教程。这是根据该教程改编的解决方案的部分概述。
首先创建一个遍历文档并查找您感兴趣的顶级标签的方法:
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()
方法,显然,您还希望添加代码以某种方式存储您读取的数据。但是希望可以使您了解如何构造解析器以处理嵌套元素。
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句