计算具有多个条件的xml元素

我有以下
XML代码,我试图使用xlst进行转换:

<setting>
    <type>house</type>
    <context>roof</context>
    <value>blue</value>
</setting>
<setting>
    <type>house</type>
    <context>kitchen</context>
    <value>red</value>
</setting>
<setting>
    <type>house</type>
    <context>floor</context>
    <value>black</value>
</setting>
<setting>
    <type>apartment</type>
    <context>roof</context>
    <value>red</value>
</setting>

我想知道setting->类型“apartment”是否具有“context-> floor”.

我尝试这样做:

<xsl:if test="count(setting[type='apartment'] and setting[context='floor']) &lt; 1">
    <!-- do what ever !-->
</xsl:if>

但它似乎没有用.关于尝试将数字转换为布尔值我有一个例外吗?有什么建议?

更新:
我发现我可以使用:

<xsl:if test="count(setting[type='apartment' and context='floor']) &lt; 1">

最佳答案 count内部的语句返回布尔值,这是不正确的. count()要求node-set能够计算节点.如果这是需要具有所需值的type和appartment元素的相同设置元素,那么您可能正在查看:

count(setting[type='apartment' and context='floor']) &lt; 1

否则,如果您需要一个具有type = apartment或context = floor的设置元素的总和(不包括具有所需值的两个元素的计数设置),您可能需要:

count(setting[type='apartment'] | setting[context='floor']) &lt; 1
点赞