Filemaker XSL - 如果节点包含特定文本 - 就行不通

时间:2014-11-14 12:55:21

标签: xml xslt if-statement contains filemaker

我有一个像这样的XML文件:

<propertys>
 <property>
  <ref>12345</ref>
  <description>Lovely house with swimming pool.</description>
 </property>
 <property>
  <ref>54321</ref>
  <description>Lovely house with outbuildings and lake.</description>
 </property>
 <property>
  <ref>67890</ref>
  <description>Lovely house with garage and further parking.</description>
 </property>
</propertys>

我有许多输出字段,如湖泊,车库,游泳池,停车场等。

当我使用XSL将此XML导入Filemaker时,我想检查描述节点是否包含单词“pool”,然后将相应的输出字段设置为是。

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" exclude-result-prefixes="xsl">
 <xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
 <xsl:template match="/">
  <FMPXMLRESULT xmlns="http://www.filemaker.com/fmpxmlresult">
  <ERRORCODE>0</ERRORCODE>
  <PRODUCT BUILD="" NAME="FileMaker" VERSION="ProAdvanced 12.0v4"/>
  <DATABASE DATEFORMAT="" LAYOUT="" NAME="" RECORDS="" TIMEFORMAT=""/>
  <METADATA>
    <FIELD EMPTYOK="NO" MAXREPEAT="1" NAME="Ref" TYPE="TEXT" />
    <FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="SwimmingPool" TYPE="TEXT" />
    <FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="Garage" TYPE="TEXT" />
    <FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="Parking" TYPE="TEXT" />
    <FIELD EMPTYOK="YES" MAXREPEAT="1" NAME="Lake" TYPE="TEXT" />       
  </METADATA>

  <RESULTSET FOUND="">
   <xsl:for-each select="propertys/property">
      <ROW RECORDID="" MODID="">

        <!-- REF -->
        <COL><DATA><xsl:value-of select="ref"/></DATA></COL>

        <COL><DATA>
        <xsl:if test="contains(description,'pool')">
        Yes
        </xsl:if>
        </DATA></COL>

        <COL><DATA>
        <xsl:if test="contains(description,'garage')">
        Yes
        </xsl:if>
        </DATA></COL>

        <COL><DATA>
        <xsl:if test="contains(description,'parking')">
        Yes
        </xsl:if>
        </DATA></COL>

        <COL><DATA>
        <xsl:if test="contains(description,'lake')">
        Yes
        </xsl:if>
        </DATA></COL>

     </ROW>
    </xsl:for-each>
  </RESULTSET>
</FMPXMLRESULT>

我已尝试过各种方式,包括应用模板,但我无法让它工作,但是花了几个小时谷歌搜索和谷歌搜索似乎都很好。

当数据进入Filemaker时,游泳池和其他字段为空白。

非常感谢!

1 个答案:

答案 0 :(得分:0)

  

当数据进入Filemaker,游泳池等领域时   是空白的。

不,他们不是空白。它们包含(当条件满足时)字符串:


         Yes

因为这是您指定为<xsl:if>语句的结果的字符串。请尝试改为:

<xsl:if test="contains(description,'pool')">Yes</xsl:if>

或:

<xsl:if test="contains(description,'pool')">
    <xsl:text>Yes</xsl:text>
</xsl:if>