首页 > 解决方案 > 查找与属性相关的元素,重点是其中一个元素

问题描述

我试图找到一种方法来确保如果具有某些属性值的元素存在于 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 元素。

标签: xmlxpathxpath-1.0

解决方案


那是因为您的 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


推荐阅读