【发布时间】:2016-05-20 00:03:57
【问题描述】:
我有以下问题:
RSS文件的原始部分:
<item>
<title> I can get data in tag this </title>
<description><p> i don't get data in this </p></description></item>
当我使用 StAX 解析器读取文件时,特殊字符 '<'; .它会自动转换为“'
的其余部分中获取数据这是我的代码:
public Feed readFeed() {
Feed feed = null;
try {
boolean isFeedHeader = true;
String description = "";
String title = "";
XMLInputFactory inputFactory = XMLInputFactory.newInstance();
InputStream in = read();
XMLEventReader eventReader = inputFactory.createXMLEventReader(in);
while (eventReader.hasNext()) {
XMLEvent event = eventReader.nextEvent();
if (event.isStartElement()) {
String localPart = event.asStartElement().getName()
.getLocalPart();
switch (localPart) {
case "title":
title = getCharacterData(event, eventReader);
break;
case "description":
description = getCharacterData(event, eventReader);
break;
}
} else if (event.isEndElement()) {
if (event.asEndElement().getName().getLocalPart() == ("item")) {
FeedMessage message = new FeedMessage();
message.setDescription(description);
message.setTitle(title);
feed.getMessages().add(message);
event = eventReader.nextEvent();
continue;
}
}
}
} catch (XMLStreamException e) {
throw new RuntimeException(e);
}
return feed;}
private String getCharacterData(XMLEvent event, XMLEventReader eventReader)
throws XMLStreamException {
String result = "";
event = eventReader.nextEvent();
if (event instanceof Characters) {
result = event.asCharacters().getData();
}
return result;}
我按照以下说明进行操作:http://www.vogella.com/tutorials/RSSFeed/article.html
【问题讨论】:
-
如何使用 stax 解析器读取这个文件(相关代码)?以及新的 xml 文件看起来如何(例如请)?
-
那么您写入新文件的代码有缺陷。也许如果你展示它,我们可以帮助确定如何。
-
第二个
<artists>不应该是像</artists>这样的结束标签吗?