使用removeContent()从JDOM文档中删除元素

Swi*_*tle 4 java xml jdom

给定以下场景,其中 xml、Geography.xml 看起来像 -

<Geography xmlns:ns="some valid namespace">
    <Country>
        <Region>
            <State>
                <City>
                    <Name></Name>
                    <Population></Population>
                </City>
            </State>
            </Region>
        </Country>
    </Geography>
Run Code Online (Sandbox Code Playgroud)

以及以下示例 java 代码 -

InputStream is = new FileInputStream("C:\\Geography.xml");
SAXBuilder saxBuilder = new SAXBuilder();
Document doc = saxBuilder.build(is);

XPath xpath = XPath.newInstance("/*/Country/Region/State/City");
Element el = (Element) xpath.selectSingleNode(doc);
boolean b = doc.removeContent(el);
Run Code Online (Sandbox Code Playgroud)

removeContent()方法不会City从 的内容列表中删除该元素doc。b 的值是false
我不明白为什么它不删除 Element,我什至尝试从 xml 中删除Name&元素只是为了看看这是否是问题,但显然不是。 我尝试的另一种方法,我不知道为什么我知道它没有本质上的不同,仍然只是为了使用- Population
Parent

Parent p = el.getParent();
boolean s = p.removeContent(new Element("City"));
Run Code Online (Sandbox Code Playgroud)

可能是什么问题?以及可能的解决方案?如果有人可以分享该方法的真实行为removeContent(),我怀疑它与父子关系有关。

for*_*two 5

当然,removeContent(Content child)如果孩子属于父母的直系孩子,则删除孩子,但在您的情况下则不然。el.detach()代替使用。