首页 > 解决方案 > 如何使用 XPath 从 XML 中的相似元素中读取多个嵌套节点?

问题描述

我试图在 Jaspersoft Studio 中使用 XPath 表达式从具有多个<cac: InvoiceLine>元素的 XML 中获取以下字段。每个 InvoiceLine 元素都是这样的。

cbc:姓名 cbc:说明 cbc:InvoicedQuantity cbc:LineExtensionAmount cbc:价格金额
项目一 第一项 描述 4 168.26 142.06
项目二 第二项说明 1 42.06 92.06

xml:

 </Invoice>
  <Other elements>
  ...
  <Other elements>
   <cac:InvoiceLine>
            <cbc:InvoicedQuantity unitCode="5B">4</cbc:InvoicedQuantity>
            <cbc:LineExtensionAmount currencyID="NZD">168.26</cbc:LineExtensionAmount>
            <cac:Item>
                <cbc:Name>Item One</cbc:Name>
                <cbc:Description>First Item Description</cbc:Description>                   
            </cac:Item>
            <cac:Price>
                <cbc:PriceAmount currencyID="NZD">142.06</cbc:PriceAmount>
            </cac:Price>
   </cac:InvoiceLine>
        <cac:InvoiceLine>
            <cbc:InvoicedQuantity unitCode="5B">1</cbc:InvoicedQuantity>
            <cbc:LineExtensionAmount currencyID="NZD">42.06</cbc:LineExtensionAmount>
            <cac:Item>
                <cbc:Name>Item Two</cbc:Name>
                <cbc:Description>Second Item Description</cbc:Description>
            </cac:Item>
            <cac:Price>
                <cbc:PriceAmount currencyID="NZD">92.06</cbc:PriceAmount>
            </cac:Price>
        </cac:InvoiceLine>
 </Invoice>

我需要在 Xpath 表达式中添加什么来获取包含这些字段的每一行数据?

我最初尝试的是/*[local-name()='Invoice']/cac:InvoiceLine,但它只是从每个 InvoiceLine 元素中获取 cbc:invoicedQantity 和 cbc:LineExtensionAmount 。

然后我尝试了这个

 /*[local-name()='Invoice']/cac:InvoiceLine |  
 /*[local-name()='Invoice']/cac:InvoiceLine/cac:Item |    
 /*[local-name()='Invoice']/cac:InvoiceLine/cac:Price

这样做会为每个表达式提供单独的记录行。我正在寻找的是这些表达式的联合作为一个记录

标签: xmlxpathjasper-reportsxpath-2.0

解决方案


推荐阅读