我的目的是将xml文件读入Dom对象,编辑dom对象,这涉及删除一些节点.
完成此操作后,我希望将Dom恢复到其原始状态,而不实际解析XML文件.
无论如何我可以克隆我第一次解析xml文件后获得的dom对象.这个想法是为了避免一直读取和解析xml,只需保留原始dom树的副本.
bdo*_*han 15
您可以在org.w3c.dom.Document上使用importNode API:
Node copy = document.importNode(node, true);
Run Code Online (Sandbox Code Playgroud)
完整的例子
import java.io.File;
import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory;
import org.w3c.dom.Document;
import org.w3c.dom.Node;
public class Demo {
public static void main(String[] args) throws Exception {
DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
DocumentBuilder db = dbf.newDocumentBuilder();
Document originalDocument = db.parse(new File("input.xml"));
Node originalRoot = originalDocument.getDocumentElement();
Document copiedDocument = db.newDocument();
Node copiedRoot = copiedDocument.importNode(originalRoot, true);
copiedDocument.appendChild(copiedRoot);
}
}
Run Code Online (Sandbox Code Playgroud)
TransformerFactory tfactory = TransformerFactory.newInstance();
Transformer tx = tfactory.newTransformer();
DOMSource source = new DOMSource(doc);
DOMResult result = new DOMResult();
tx.transform(source,result);
return (Document)result.getNode();
Run Code Online (Sandbox Code Playgroud)
这将是用于制作DOM文档副本的Java 1.5解决方案.看看Transformer Factory和Transformer
您可以克隆树或仅克隆具有DOM的节点cloneNode(boolean isDeepCopy)API。
Document originalDoc = parseDoc();
Document clonedDoc = originalDoc.cloneNode(true);
Run Code Online (Sandbox Code Playgroud)
不幸的是,由于Document上的cloneNode()是(根据API)特定于实现的,因此我们必须采用防弹方式,即创建一个新的Document并从原始文档中导入克隆的节点:
...
Document clonedDoc = documentFactory.newDocument();
cloneDoc.appendChild(
cloneDoc.importNode(originalDoc.getDocumentElement(), true)
);
Run Code Online (Sandbox Code Playgroud)
请注意,所有操作都不是线程安全的,因此请仅在本地使用它们,或者在Thread-Local或同步它们。