Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/java/384.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Java 将新的XML节点保存到文件_Java_Xml_Dom_Nodelist - Fatal编程技术网

Java 将新的XML节点保存到文件

Java 将新的XML节点保存到文件,java,xml,dom,nodelist,Java,Xml,Dom,Nodelist,我正在尝试将包含XML的nodeList节点保存为新文件,下面是获取新XML文档并拆分为更小的XMLs的节点列表: public void split(Document inDocument) throws ParserConfigurationException, SAXException, IOException { DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(

我正在尝试将包含
XML
nodeList
节点保存为新文件,下面是获取新
XML
文档并拆分为更小的
XMLs
的节点列表:

public void split(Document inDocument) throws ParserConfigurationException,
            SAXException, IOException {
        DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance();
        DocumentBuilder builder = factory.newDocumentBuilder();
        SaveXML savePerJob = new SaveXML();
        // Load the input XML document, parse it and return an instance of the
        // Document class.
        Document document = inDocument;
        //all elements
        //jobs
        NodeList nodes = document.getDocumentElement().getChildNodes();
        NodeList jobs = nodes.item(7).getChildNodes();
        for(int j =0; j<jobs.getLength(); j++){
            Node itm = jobs.item(j);
            String itmName = itm.getFirstChild().getNodeName();
            String itmID = itm.getFirstChild().getTextContent();
            System.out.println("name: " + itmName + " value: " + itmID);
            //here I want to save the node as a new .xml file
        }
    }
现在我想将节点
itm
保存为new
.xml
文件,但我没有找到按原样返回节点的函数。
谢谢。

您可以将节点转换为字符串,并将此字符串保存到
.xml
文件中

将节点转换为字符串 下面的方法将节点转换为xml字符串。它是一个只使用JDK的解决方案,不需要依赖项

import org.w3c.dom.Node;
import org.w3c.dom.NodeList;

import javax.xml.transform.OutputKeys;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerException;
import javax.xml.transform.TransformerFactory;
import javax.xml.transform.dom.DOMSource;
import javax.xml.transform.stream.StreamResult;
import javax.xml.xpath.XPath;
import javax.xml.xpath.XPathConstants;
import javax.xml.xpath.XPathExpression;
import javax.xml.xpath.XPathExpressionException;
import javax.xml.xpath.XPathFactory;
import java.io.StringWriter;

public static String toString(Node node, boolean omitXmlDeclaration, boolean prettyPrint) {
    if (node == null) {
        throw new IllegalArgumentException("node is null.");
    }

    try {
        // Remove unwanted whitespaces
        node.normalize();
        XPath xpath = XPathFactory.newInstance().newXPath();
        XPathExpression expr = xpath.compile("//text()[normalize-space()='']");
        NodeList nodeList = (NodeList)expr.evaluate(node, XPathConstants.NODESET);

        for (int i = 0; i < nodeList.getLength(); ++i) {
            Node nd = nodeList.item(i);
            nd.getParentNode().removeChild(nd);
        }

        // Create and setup transformer
        Transformer transformer =  TransformerFactory.newInstance().newTransformer();
        transformer.setOutputProperty(OutputKeys.ENCODING, "UTF-8");
        
        if (omitXmlDeclaration == true) {
           transformer.setOutputProperty(OutputKeys.OMIT_XML_DECLARATION, "yes");
        }

        if (prettyPrint == true) {
           transformer.setOutputProperty(OutputKeys.INDENT, "yes");
           transformer.setOutputProperty("{http://xml.apache.org/xslt}indent-amount", "4");
        }

        // Turn the node into a string
        StringWriter writer = new StringWriter();
        transformer.transform(new DOMSource(node), new StreamResult(writer));
        return writer.toString();
    } catch (TransformerException e) {
        throw new RuntimeException(e);
    } catch (XPathExpressionException e) {
        throw new RuntimeException(e);
    }
}
import org.w3c.dom.Node;
导入org.w3c.dom.NodeList;
导入javax.xml.transform.OutputKeys;
导入javax.xml.transform.Transformer;
导入javax.xml.transform.TransformerException;
导入javax.xml.transform.TransformerFactory;
导入javax.xml.transform.dom.DOMSource;
导入javax.xml.transform.stream.StreamResult;
导入javax.xml.xpath.xpath;
导入javax.xml.xpath.XPathConstants;
导入javax.xml.xpath.XPathExpression;
导入javax.xml.xpath.XPathExpressionException;
导入javax.xml.xpath.XPathFactory;
导入java.io.StringWriter;
公共静态字符串toString(节点节点、布尔省略XMLDeclaration、布尔预打印){
if(node==null){
抛出新的IllegalArgumentException(“节点为null”);
}
试一试{
//删除不需要的空白
node.normalize();
XPath=XPathFactory.newInstance().newXPath();
XPathExpression expr=xpath.compile(“//text()[normalize-space()=”);
NodeList NodeList=(NodeList)expr.evaluate(node,XPathConstants.NODESET);
对于(int i=0;i
这里有一种可能性:

void save(Node node, OutputStream stream) throws Exception {
    DOMImplementationLS ls = (DOMImplementationLS) node.getOwnerDocument().getImplementation();
    LSOutput out = ls.createLSOutput();
    out.setByteStream(stream);
    LSSerializer ser = ls.createLSSerializer();
    ser.write(node, out);
}

也许您应该确保
节点
确实是一个
元素
,但我把它留作练习。

是的,但它将是一个没有我想要的.xml标记的字符串。@ItsikMauyhas请检查我添加到答案中的代码段。字符串输出将包括xml标记选项。indent()'不要编译。@ItsikMauyhas将
options.indent()
替换为
“4”
。请参阅my update.BTW-我希望结果包含XML标记。如果节点不是元素,我无法返回其IDPerhaps,但您没有任何检查以确定正在处理元素。总之,您的代码对输入文档中的格式更改非常敏感,但这是另一回事。
void save(Node node, OutputStream stream) throws Exception {
    DOMImplementationLS ls = (DOMImplementationLS) node.getOwnerDocument().getImplementation();
    LSOutput out = ls.createLSOutput();
    out.setByteStream(stream);
    LSSerializer ser = ls.createLSSerializer();
    ser.write(node, out);
}