Filemaker XSL-如果节点包含特定文本,则将不起作用

TVRV8S

我有一个像这样的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>

我已经尝试了所有方法,包括应用模板,但我无法使它正常工作,但是花了几个小时在Google搜寻和Google搜寻上,一切似乎都还不错。

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

帮助非常感谢!

michael.hor257k

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

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


         是的

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

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

或者:

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

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章