0

以下のxmlファイルがあり、XSLTを使用して変換し、すべての要素と属性を保持したいのですが、値が「SQL:」で始まる属性に発生した場合は、SQLを実行して置換します解決されたSQLの属性値(http://msdn.microsoft.com/en-us/library/533texsx(VS.90).aspxが含まれます。現在、問題が発生しました:現在のノードタイプかどうかを確認する方法は属性であり、属性値を置き換える方法は、次のようにVisualStudioのデフォルトテンプレートに基づいています。

サンプルのxmlファイル(実際には多くの要素があります):

<DM>
  <DV  id="SQL:Select something from db">
    <Sample aid="SQL:Select something from db">

    </Sample>
  </DV>
  <DV  id="SQL:Select something from db">
    <Sample aid="SQL:Select something from db">
    </Sample>
  </DV>
</DM>

デフォルトのxslt:

<?xml version="1.0" encoding="utf-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
    xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl"
               xmlns:ms="urn:schemas-microsoft-com:xslt" >
  <xsl:output method="xml" indent="yes"/>

  <xsl:template match="@* | node()">
    <xsl:copy>
      <xsl:apply-templates select="@* | node()"/>
    </xsl:copy>
  </xsl:template>
</xsl:stylesheet>
4

2 に答える 2

2

このスタイルシート:

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
    <xsl:template match="@*|node()">
        <xsl:copy>
            <xsl:apply-templates select="@*|node()"/>
        </xsl:copy>
    </xsl:template>
    <xsl:template match="@*[starts-with(translate(substring(.,1,4),'sql','SQL'),'SQL:')]">
        <xsl:attribute name="{name()}">
            <xsl:value-of select="'From SQL!'"/>
        </xsl:attribute>
    </xsl:template>
</xsl:stylesheet>

結果:

<DM>
    <DV id="From SQL!">
        <Sample aid="From SQL!"></Sample>
    </DV>
    <DV id="From SQL!">
        <Sample aid="From SQL!"></Sample>
    </DV>
</DM>

:「恒等変換」を壊す必要はありません。で結果ツリーに属性を追加しますxsl:attribute

于 2010-07-20T13:28:31.300 に答える
1

1つのテンプレートを使用して、ノードと属性の両方を照合しています。2つの別々のテンプレートを使用すると、それらを区別するのが簡単になります。

<!-- One template for nodes -->
<xsl:template match="node()">
  <xsl:copy>
    <xsl:apply-templates select="@* | node()"/>
  </xsl:copy>
</xsl:template>

<!-- Another template for attributes -->
<xsl:template match="@*">
  <!-- Special case for SQL attributes goes here -->
</xsl:template>

文字列が特定の部分文字列で始まるかどうかを判断するには、starts-with()関数を使用する必要があります。次のように使用できます。

<xsl:if test="starts-with(.,'SQL:')">
  <!-- The current node starts with "SQL:" -->
</xsl:if>
于 2010-07-20T12:53:35.957 に答える