2012-03-08 11 views
1

私は非常に簡単なクエリを持っていますが、それを解決する最も簡単でエレガントな方法を見つけることはできません。私の入力XMLに、文字列の内容が "YY nnn"のタグがある場合、YYは英数字2文字、その後にスペース、その後は4つの数値が続きます。私の出力XMLでは、数字が4文字の場合、スペースを取り除く必要があります。 "YY nnnn"の場合はスペースを保持します。私は文字列の長さのチェックを試して、その後、スペースを削除しますが、私はより単純な方法が必要であると確信しています。XSLTを使用した長さ条件に基づくXMLタグ値の空白スペース

アイデア?

私は変換のためにlinuxでxlstprocを使用しています。

ありがとうございます!

+0

を確実に行うことができます! :) –

+0

もしカウントが3でも4でもないなら、それは5または2であるのと同じように '(" A1 23456 "または" BZ 12 ")'スペースを保持すべきかどうか? –

+0

。私のコードでは、 ''のスペースを取り除くことなく、コピーしています。あなたの要件としてそれを変更します。 :) –

答えて

1

サンプル入力XML:

<?xml version="1.0" encoding="utf-8"?> 
<root> 
    <MyNode>AZ 1234</MyNode> 
    <MyNode>A3 123</MyNode> 
    <MyNode>7Z 12345</MyNode> 
    <MyNode>15 23</MyNode> 
</root> 

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" 
> 
    <xsl:output method="xml" indent="yes"/> 

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

    <xsl:template match="MyNode"> 
    <xsl:copy> 
     <xsl:choose> 
     <xsl:when test="string-length(substring-after(.,' '))='4'"> 
      <xsl:value-of select="concat(substring-before(.,' '), substring-after(.,' '))"/> 
     </xsl:when> 
     <xsl:when test="string-length(substring-after(.,' '))='3'"> 
      <xsl:value-of select="."/> 
     </xsl:when> 
     <xsl:otherwise> 
      <xsl:value-of select="."/> 
     </xsl:otherwise> 
     </xsl:choose> 
    </xsl:copy> 
    </xsl:template> 
</xsl:stylesheet> 

出力:

<?xml version="1.0" encoding="utf-8"?> 
<root> 
    <MyNode>AZ1234</MyNode> 
    <MyNode>A3 123</MyNode> 
    <MyNode>7Z 12345</MyNode> 
    <MyNode>15 23</MyNode> 
</root> 
+0

@Surge、no。これが可能な唯一の方法です。 XSLT 2.0でも**これは可能なアプローチだと思う**。 –

+0

ありがとうAravind - 私は7つの文字(YY_NNNN)を確認し、translate()またはconcat()を行うことができ、それだけで入力を残していくつかの簡潔な方法があるかもしれないと思った。あなたの以前の質問に答えるために、それは4つの数値を超えません。最小値はYY_N(1つの数値)です。 – Surge

+0

うれしいことはあなたを助けることができます。私は質問があれば教えてください:) –

関連する問題