Android XmlPullParser:在RSS提要中读取名称空间
我正在解析一个XML提要,该提要如下所示:Android XmlPullParser:在RSS提要中读取名称空间,android,xml,android-xmlpullparser,Android,Xml,Android Xmlpullparser,我正在解析一个XML提要,该提要如下所示: <?xml version="1.0" encoding="UTF-8"?> <rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:cc="http://web.resource.org/cc/" xmlns:itunes="http://www.itunes.com/dtds/podcast-1.0.dtd" xmlns:media="http://sea
<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:cc="http://web.resource.org/cc/" xmlns:itunes="http://www.itunes.com/dtds/podcast-1.0.dtd" xmlns:media="http://search.yahoo.com/mrss/" xmlns:rdf="http://www.w3.org/1999/02/22-rdf-syntax-ns#">
<channel>
...
</channel>
</rss>
...
我想做的一件事是通过URL获取所有名称空间,并获取相关的前缀,以便稍后进行解析。例如,如果我知道itunes DTD位于:我想获取相关前缀。下面是一些我想用来实现这一点的代码:
if(parser.getEventType() != START_TAG && !"rss".equalsIgnoreCase(parser.getName())) {
throw new IllegalStateException();
}
for(int i=0; i<parser.getAttributeCount(); i++) {
if(!"xmlns".equalsIgnoreCase(parser.getAttributePrefix(i))) {
continue;
}
String namespace = parser.getAttributeName(i);
String namespaceUrl = parser.getAttributeValue(i);
if(namespaceUrl.contains("www.itunes.com")) {
ITUNES_NAMESPACE = namespace;
} else if(namespaceUrl.contains("www.w3.org/2005/Atom")) {
ATOM_NAMESPACE = namespace;
}
}
if(parser.getEventType()!=START_TAG&&!“rss”.equalsIgnoreCase(parser.getName())){
抛出新的非法状态异常();
}
对于(int i=0;i