DOM4J选择子节点

4

我有一个标签为book,然后我读出了2个节点:

CCUSTBLS_KundennummerBLS

CCOMP_MandantFIBU

之后,我有了"Lieferadresse"节点。现在我想要一个循环,遍历"Lieferadresse"节点。我的问题是,每次我都看到来自所有"Lieferadresse"的子节点,而不仅仅是第一个"Lieferadresse"的子节点。我认为我的Xpath是错误的。

<?xml version="1.0" encoding="utf-8"?>
<eDoc>
    <book>
        <CCUSTBLS_KundennummerBLS>1143</CCUSTBLS_KundennummerBLS>
        <CCOMP_MandantFIBU>1</CCOMP_MandantFIBU>
        <Lieferadresse>
            <TSHIPBLS_NrLieferadresse>1</TSHIPBLS_NrLieferadresse> 
            <TCUSTBLS_Kunde>1143</TCUSTBLS_Kunde>

        </Lieferadresse>
        <Lieferadresse>
            <TSHIPBLS_NrLieferadresse>2</TSHIPBLS_NrLieferadresse> 
            <TCUSTBLS_Kunde>1143</TCUSTBLS_Kunde>

        </Lieferadresse>
        <Lieferadresse>
            <TSHIPBLS_NrLieferadresse>3</TSHIPBLS_NrLieferadresse> 
            <TCUSTBLS_Kunde>1143</TCUSTBLS_Kunde>

        </Lieferadresse>
    </book>
</eDoc>

Java类

List<Node> nodes = document.selectNodes("/eDoc/book/child::*");
    List<Node> list = nodes;

    for (Node node : list) {
        String nodeName = node.getName();

        if("Lieferadresse".equals(nodeName)){
            List<Node> nodesDelivery = document.selectNodes("//"+nodeName+"/child::*");
            System.out.println("------------------------------------------------------");
            for(Node nodeDelivery : nodesDelivery){
                System.out.println(nodeDelivery.getName() + " " +nodeDelivery.getText());
            }

        }else{
            System.out.println(nodeName + " " +node.getText());
        }

    }

结果:

    Root element :eDoc
CCUSTBLS_KundennummerBLS 1143
CCOMP_MandantFIBU 1
------------------------------------------------------
TSHIPBLS_NrLieferadresse 1
TCUSTBLS_Kunde 1143
TSHIPBLS_NrLieferadresse 2
TCUSTBLS_Kunde 1143
TSHIPBLS_NrLieferadresse 3
TCUSTBLS_Kunde 1143
------------------------------------------------------
------------------------------------------------------
TSHIPBLS_NrLieferadresse 1
TCUSTBLS_Kunde 1143
TSHIPBLS_NrLieferadresse 2
TCUSTBLS_Kunde 1143
TSHIPBLS_NrLieferadresse 3
TCUSTBLS_Kunde 1143
------------------------------------------------------
------------------------------------------------------
TSHIPBLS_NrLieferadresse 1
TCUSTBLS_Kunde 1143
TSHIPBLS_NrLieferadresse 2
TCUSTBLS_Kunde 1143
TSHIPBLS_NrLieferadresse 3
TCUSTBLS_Kunde 1143
------------------------------------------------------
1个回答

5

我现在使用一个计数器。你认为这样可以吗?List<Node> nodesLeiferadresse =node.selectNodes("//Lieferadresse["+counterDeliveryAdress+"]"); - User1751

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接