xml - 查找与属性相关的元素,重点是其中一个元素
问题描述
我试图找到一种方法来确保如果具有某些属性值的元素存在于 XML 中,则它们使用 XPath 具有匹配的不同元素。
我正在为我的组织发出的信息开发数据验证器。我需要执行的验证之一是,如果容器 2 中有一个 Description 元素,该元素具有一个具有 GNC 字属性的 Description Type 元素,则需要有一个 Item 元素,其 Item Type 元素容器 1 具有相同的内部 ID 值和 C 或 G 的字值。
示例 XML:
<Root>
<Container1 ID="38715795">
<Item ID="119479" InternalID="2090205">
<ItemType Word="C">A Value</ItemType>
</Item>
<Item ID="119480" InternalID="2090206">
<ItemType Word="NP">B Value</ItemType>
</Item>
<Item ID="175656" InternalID="2137464">
<ItemType Word="C">A Value</ItemType>
</Item>
</Container1>
<Container2 ID="38715802">
<Description ID="119479" InternalID="2090205">
<DescriptionType Word="GNC">Description Z</DescriptionType>
</Description>
<Description ID="119480" InternalID="2090206">
<DescriptionType Word="P">Description W</DescriptionType>
</Description>
<Description ID="175656" InternalID="2137464">
<DescriptionType Word="P">Description Z</DescriptionType>
</Description>
</Container2>
</Root>
我想我已经很接近了。经过大量查找和 Google Foo,我发现了 XPath 函数。以下让我接近:
boolean(/Root/Container2/Description/@InternalID[../DescriptionType/@Word = 'GNC'] != /Root/Container1/Item/@InternalChargeID[../ItemType/@Word = "C" or ../ItemType/@Word = "G"])
问题是,可能有一个 Item 元素具有 C 或 G Word 值而没有匹配的 Description 值,这没关系。示例 XML 中的情况应该没问题,但路径返回的是 true 而不是 false。我需要找到一种方法来检查每个 Description 元素是否有一个 Item 元素,而不关心每个 Item 元素是否有一个 Description 元素。
解决方案
那是因为您的 xpath 在右侧:
/Root/Container1/Item/@InternalChargeID[../ItemType/@Word = "C" or ../ItemType/@Word = "G"]
两者都匹配
<Item ID="119479" InternalID="2090205">
<Item ID="175656" InternalID="2137464">
这个 xpath 返回 false:
boolean(/Root/Container2/Description[DescriptionType/@Word = 'GNC']/@InternalID !=
/Root/Container1/Item[@InternalID =
/Root/Container2/Description[DescriptionType/@Word =
'GNC']/@InternalID][ItemType/@Word = 'C' or ItemType/@Word = 'G']/@InternalID)
Item
它向具有相同的节点添加谓词@InternalID
推荐阅读
- youtube - YouTube 数据 API 无法搜索视频
- azure - 如何在删除之前保留 vm 的私有 ip 并将其用于另一个 azure vm
- python - 如何在不使用任何导入的情况下不断向字符串添加字母直到递归结束?
- selenium - Selenium-side-runner 在输入前不清除输入字段但与 Selenium Ide 一起使用
- c - 有人知道非ASCII编码吗?
- python - pyspark 的 CSV 文件中的数据未正确映射?
- vespa - 是否可以在搜索定义中的 JSON 对象内创建 JSON 数组,并且所有字段都可以在 vespa.ai 中搜索?
- otrs - 停止自动清理 OTRS 中的 js-cache?
- vba - 如何自动加载 EDITABLE PowerPoint Personal VBA Macros 文件?
- python - Python3.7 缺少 pip 包