首页 > 解决方案 > 如何使用不包含属性和元素

问题描述

<newproducts>
        <number id ="1">
        <number id ="2">
        <number id ="3">
        <number id ="4">
        <number id ="5">
</newproducts>    
<products>   
        <number>2</number>
        <number>3</number>
        <number>4</number>
</products>

number id 包含 2, 3, 4 所以输出应该是这样的

<number>1</number>
<number>5</number>

因为 1 和 5 不在数字 id 中所以我想输出它们

为什么这不起作用?

for $z in /newproducts/number[@id/string() != /products/number/text()]
return 
<number>{$z}</number>

这是否可能与 contains 函数或存在甚至是 if then else ?

标签: xpathxquerycontainsexists

解决方案


!= 运算符实际上是“序列中至少有一项不同的项目”。如果您需要有效地检查“序列中是否没有相同的项目”,请使用:

not(@id/string = /products/number/text())

代替

@id/string() != /products/number/text()

尝试如下修改(我用根节点包装了您的输入,并在此过程中更正了一些拼写错误):

let $list :=
    <list>
    <newproducts>
            <number id ="1"/>
            <number id ="2"/>
            <number id ="3"/>
            <number id ="4"/>
            <number id ="5"/>
    </newproducts>    
    <products>   
            <number>2</number>
            <number>3</number>
            <number>4</number>
    </products>
    </list>
return
for $z in $list/newproducts/number[not(@id/string() = $list/products/number/text())]
return <number>{$z}</number> 

返回:

<number>
  <number id="1"/>
</number>
<number>
  <number id="5"/>
</number>

但是您的预期输出没有包含在数字中的数字,因此将您的 return 子句从

<number>{$z}</number>  

类似于:

<number>{$z/@id/string()}</number>  

例如:

...
for $z in $list/newproducts/number[not(@id/string() = $list/products/number/text())]
return <number>{$z/@id/string()}</number>  

返回

<number>1</number>
<number>5</number>

推荐阅读