gpt4 book ai didi

java - 解析 XML,调用 doc.getDocumentElement().getNodeName() 并得到 "h1"的错误输出?

转载 作者:行者123 更新时间:2023-12-01 15:33:08 25 4
gpt4 key购买 nike

这是我的代码:(来源:http://www.androidhive.info/2011/11/android-xml-parsing-tutorial/)

这是我的 XML 文件:已删除

运行时,出现 NoResults,并且我得到字符串“h1”,它不是文件中的 xml 标记。我不确定我的 xml 文件是否转换不正确,或者我无法成功找到“members”标签。

    ArrayList<HashMap<String, String>> mylist = new ArrayList<HashMap<String, String>>();

XMLParser parse = new XMLParser();
String xml = parse.getXmlFromUrl(url); // getting XML
Document doc = parse.getDomElement(xml); // getting DOM element

NodeList nodes = doc.getElementsByTagName(KEY_MEMBER);

// looping through all item nodes <member>
for (int i = 0; i < nodes.getLength(); i++) {
HashMap<String, String> map = new HashMap<String, String>();

Element e = (Element)nodes.item(i);
map.put(KEY_FNAME, parse.getValue(e, KEY_FNAME));
map.put(KEY_MNAME, parse.getValue(e, KEY_MNAME));
map.put(KEY_LNAME, parse.getValue(e, KEY_LNAME));
map.put(KEY_STATE, parse.getValue(e, KEY_STATE));
map.put(KEY_PARTY, parse.getValue(e, KEY_PARTY));
mylist.add(map);
}

if((nodes.getLength() <= 0)){
Toast.makeText(AndroidXMLParsingActivity.this, "NoResults " + doc.getDocumentElement().getNodeName(), Toast.LENGTH_LONG).show();
finish();
}

最佳答案

由于“h1”是一个 html 标签,我猜测您点击的 url 返回的是 html,而不是 xml。当然,确定这一点的一个简单方法是在解析 xml 字符串之前将其打印出来。

仅供引用,不确定在 android 上编码的限制,但在解析 xml 文档之前将其转换为字符串通常是一个坏主意(出于多种原因,从“破坏”xml 到不必要地增加内存)用法)。

关于java - 解析 XML,调用 doc.getDocumentElement().getNodeName() 并得到 "h1"的错误输出?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9321195/

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