有 Java 编程相关的问题?

你可以在下面搜索框中键入要查询的问题!

使用JDOM Java拆分XML

我有以下XML字符串

<Engineers>
    <Engineer>
        <Name>JOHN</Name>
        <Position>STL</Position>
        <Team>SS</Team>
    </Engineer>
    <Engineer>
        <Name>UDAY</Name>
        <Position>TL</Position>
        <Team>SG</Team>
    </Engineer>
    <Engineer>
        <Name>INDRA</Name>
        <Position>Director</Position>
        <Team>PP</Team>
    </Engineer>
</Engineers>

当Xpath以工程师/工程师的身份给出时,我需要将这个xml拆分成更小的xml字符串

较小的xml字符串如下所示

    <Engineer>
        <Name>INDRA</Name>
        <Position>Director</Position>
        <Team>PP</Team>
    </Engineer>

<Engineer>
        <Name>JOHN</Name>
        <Position>STL</Position>
        <Team>SS</Team>
 </Engineer>

我已经使用saxon xpath和JDOM实现了以下内容

import net.sf.saxon.Configuration;
import net.sf.saxon.lib.NamespaceConstant;
import net.sf.saxon.om.DocumentInfo;
import net.sf.saxon.om.NodeInfo;
import net.sf.saxon.s9api.DocumentBuilder;
import net.sf.saxon.s9api.XPathCompiler;
import net.sf.saxon.s9api.XPathSelector;
import net.sf.saxon.s9api.XdmNode;
import net.sf.saxon.xpath.XPathFactoryImpl;
import org.apache.axiom.om.OMElement;
import org.apache.axiom.om.impl.builder.StAXOMBuilder;
import org.junit.Test;
import org.xml.sax.InputSource;

import java.io.File;
import java.io.FileInputStream;
import java.io.StringReader;
import java.util.Iterator;
import java.util.List;
import javax.xml.transform.sax.SAXSource;
import javax.xml.transform.stream.StreamSource;
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 javax.xml.xpath.XPathFactoryConfigurationException;

 public void testXML() throws XPathFactoryConfigurationException, XPathExpressionException, Exception {

        System.setProperty("javax.xml.xpath.XPathFactory:" + NamespaceConstant.OBJECT_MODEL_JDOM,
                "net.sf.saxon.xpath.XPathFactoryImpl");
        XPathFactory xPathFactory = XPathFactory.newInstance(NamespaceConstant.OBJECT_MODEL_JDOM);
        XPath xPath = xPathFactory.newXPath();
        InputSource inputSource = new InputSource(new File(filename).toURI().toString());
        SAXSource saxSource = new SAXSource(inputSource);
        Configuration config = ((XPathFactoryImpl) xPathFactory).getConfiguration();
        DocumentInfo document = config.buildDocument(saxSource);
        XPathExpression xPathExpression = xPath.compile("//Engineers/Engineer");
        List matches = (List) xPathExpression.evaluate(document, XPathConstants.NODESET);
        if (matches != null) {
            for (Iterator iter = matches.iterator(); iter.hasNext(); ) {
                NodeInfo node = (NodeInfo) iter.next();
                System.out.println(node.getDisplayName() + " - " + node.getStringValue());
            }
        }

    }

它给出了以下结果

Engineer - 
        JOHN
        STL
        SS

Engineer - 
        UDAY
        TL
        SG

Engineer - 
        INDRA
        Director
        PP

如何更改代码以获得所需的输出?或者有没有办法在Engineer中获取子属性(姓名、职位、团队)的名称


共 (1) 个答案

  1. # 1 楼答案

    如果您正在使用JDOM来进行这项工作,您应该考虑使用本地JDOM方法而不是通过SAXON运行抽象。p> <>考虑一下:

    import org.jdom2.Document;
    import org.jdom2.Element;
    import org.jdom2.xpath.XPathFactory;
    import org.jdom2.xpath.XPAthExpression;
    import org.jdom2.output.XMLOutputter;
    import org.jdom2.input.SAXBuilder;
    import org.jdom2.filter.Filters;
    
    ....
    
        XPathExpression xpe = XPathFactory.instance()
             .compile("//Engineers/Engineer", Filters.element());
    
        Document doc = new SAXBuilder().build(new File(filename));
    
        XMLOutputter xout = new XMLOutputter(Format.getPrettyFormat());
    
        for (Element e : xpe.evaluate(doc)) {
            xout.output(e, System.out);
        }