10

假设您有一个这样的 XML 文档:

<root>
  That was a <b boldness="very">very bold</b> move.
</root>

假设XmlPullParser是在根的开始标签上。有没有一种方便的方法可以将所有文本读取root到DOM 中?StringinnerHtml

还是我必须自己编写一个实用方法来重新创建已解析的标签?当然,这对我来说似乎是在浪费时间。

String myDesiredString = "That was a <b boldness=\"very\">very bold</b> move."
4

1 回答 1

12

这个方法应该覆盖它,但不处理单例标签或命名空间。

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;
}
于 2013-04-17T20:33:47.253 回答