10

次のような XML ドキュメントがあるとします。

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

がルートXmlPullParserの開始タグにあるとします。root内のすべてのテキストを DOMStringのように読み取る便利な方法はありますか?innerHtml

または、解析されたタグを再作成するユーティリティ メソッドを自分で作成する必要がありますか? もちろん、これは私にとって時間の無駄のように思えます。

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 に答える