我有这种从XML文件中删除节点的方法:
public static void deleteElement(Document doc, String elementType, String tagName, String valueToCheck) {
// <elementType>
NodeList nodes = doc.getElementsByTagName(elementType);
System.out.println("NODES: "+nodes.getLength());
for (int i = 0; i < nodes.getLength(); i++) {
Element person = (Element) nodes.item(i);
// <tagName>
Element name = (Element) person.getElementsByTagName(tagName).item(0);
String pName = name.getTextContent();
System.out.println(pName);
if (pName.equals(valueToCheck)) {
person.getParentNode().removeChild(person);
System.out.println("match" + pName);
}
}
System.out.println("NODES AFTER DELETE: "+nodes.getLength());
}
其中我指定了根元素,要检查的标记和要检查的值。
在我的XML上:
<?xml version="1.0"?>
<book>
<person>
<id>1</id>
<name>Person 1</name>
</person>
<person>
<id>1</id>
<name>Person 2</name>
</person>
<person>
<id>3</id>
<name>Person 3</name>
</person>
<person>
<id>4</id>
<name>Person 3</name>
</person>
</book>
使用参数person
,name
,Person 3
执行方法后的输出是:
<?xml version="1.0" encoding="UTF-8"?>
<book>
<person>
<id>1</id>
<name>Person 1</name>
</person>
<person>
<id>1</id>
<name>Person 2</name>
</person>
<person>
<id>4</id>
<name>Person 3</name>
</person>
</book>
即。只有第一次出现被删除......任何想法为什么?
答案 0 :(得分:1)
DOM节点列表 live ,换句话说,当您修改文档时,节点列表会更改以反映文档的新状态。在循环的第三次迭代期间,从文档中删除第一个匹配元素(item(2)
)。这也导致它从nodes
列表中消失,将列表缩短一个节点并将其后的所有内容移到一个索引上 - 第二个匹配节点变为item(2)
。然后你递增i
并找到== nodes.getLength()
并且循环结束而不处理最后一个条目。
为避免这种情况,请向后迭代:
for (int i = nodes.getLength() - 1; i >= 0; i--)