如何解决如何使用 XPath 从 XML 中的相似元素读取多个嵌套节点?
我正在尝试在 Jaspersoft Studio 中使用 XPath 表达式从具有多个 <cac: InvoiceLine>
元素的 XML 中获取以下字段。每个 InvoiceLine 元素都是这样的。
cbc:姓名 | cbc:描述 | cbc:InvoicedQuantity | cbc:LineExtensionAmount | cbc:PriceAmount |
---|---|---|---|---|
项目一 | 第一项描述 | 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
这样做会为每个表达式提供单独的记录行。我正在寻找的是这些表达式的联合作为一个记录
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。