xml - 如何使用 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
这样做会为每个表达式提供单独的记录行。我正在寻找的是这些表达式的联合作为一个记录
解决方案
推荐阅读
- python - Pandas:使用合并的单元格和空白值解析 Excel 电子表格
- mysql - 常规日志移动另一个表
- angular - Angular Storybook 订阅输出
- amazon-web-services - SOCK JS / Spring Boot 与 AWS Websocket API 网关
- html - 如何将图标图像完美居中
- css - GtkCssProvider 和 CSS 样式的问题
- python - 创建用于时间序列分析的表,包括计数
- javascript - React 滚动到底部仅适用于第一次(内部演示)
- json - Instaloader JSON 文件:将 200 个 JSON 文件转换为单个 CSV (Python 3.7)
- windows - Bonobo git 服务器无法进行身份验证