假设您有一个类似的XML文档:
<root>
That was a <b boldness="very">very bold</b> move.
</root>
假设XmlPullParser
位于root的开始标记上。是否有方便的方法将root
中的所有文本读取到String
,有点像DOM中的innerHtml
?
或者我是否必须自己编写一个实用程序方法来重新创建解析后的标记?这当然对我来说似乎是浪费时间。
String myDesiredString = "That was a <b boldness=\"very\">very bold</b> move."
答案 0 :(得分:10)
此方法应该覆盖它,但不处理单例标记或命名空间。
public static String getInnerXml(XmlPullParser parser)
throws XmlPullParserException, IOException {
StringBuilder sb = new StringBuilder();
int depth = 1;
while (depth != 0) {
switch (parser.next()) {
case XmlPullParser.END_TAG:
depth--;
if (depth > 0) {
sb.append("</" + parser.getName() + ">");
}
break;
case XmlPullParser.START_TAG:
depth++;
StringBuilder attrs = new StringBuilder();
for (int i = 0; i < parser.getAttributeCount(); i++) {
attrs.append(parser.getAttributeName(i) + "=\""
+ parser.getAttributeValue(i) + "\" ");
}
sb.append("<" + parser.getName() + " " + attrs.toString() + ">");
break;
default:
sb.append(parser.getText());
break;
}
}
String content = sb.toString();
return content;
}