次のXMLをJSONに変換したい:
<Table>
<Row>
<Column name="Column 1">outter quotation text and &qout;inner quotation text&qout;</Column>
<Column name="Column 2">
Some text with two 'new line' characters at the beginning (sometimes with &qout;inner quotation text&qout; also)</Column>
</Row>
</Table>
有効なjsonを使用するには、すべての「改行」文字(

)を削除して、に置き換える&qout;
必要があり\"
ます。
このコードは「新しい行」を削除するのに役立つようです。
<xsl:template name="escapeNewLine">
<xsl:param name="pText" select="." />
<xsl:if test="string-length($pText) > 0">
<xsl:value-of select="substring-before(concat($pText, '
'), '
')" />
<xsl:if test="contains($pText, '
')">
<xsl:text></xsl:text>
<xsl:call-template name="escapeNewLine"><xsl:with-param name="pText" select="substring-after($pText, '
')" /></xsl:call-template>
</xsl:if>
</xsl:if>
</xsl:template>
引用符を置き換えるのに似たもの:
<xsl:template name="escapeQuote">
<xsl:param name="pText" select="." />
<xsl:if test="string-length($pText) > 0">
<xsl:value-of select="substring-before(concat($pText, '&qout;'), '&qout;')" />
<xsl:if test="contains($pText, '&qout;')">
<xsl:text>\"</xsl:text>
<xsl:call-template name="escapeQuote">
<xsl:with-param name="pText" select="substring-after($pText, '&qout;')" />
</xsl:call-template>
</xsl:if>
</xsl:if>
</xsl:template>
私のスタイルシート:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="text" />
<xsl:template match="/">
"data":[
<xsl:for-each select="Table/Row">
<xsl:if test="position() > 1">,</xsl:if>
{
<xsl:for-each select="Column">
<xsl:if test="position() > 1">,</xsl:if>
"<xsl:value-of select="@name" />":
"
<xsl:call-template name="escapeQuote" />
<xsl:call-template name="escapeNewLine" />
<!-- <xsl:value-of select="." /> -->
"
</xsl:for-each>
}
</xsl:for-each>]
</xsl:template>
</xsl:stylesheet>
私の質問は、両方のテンプレートを同じノードに適用する方法ですか?だからこれの代わりに:
{"data":[
{"Column 1":"outter quotation text and \"inner quotation text\" outter quotation text and &qout;inner quotation text&qout;"},
{"Column 2":"Some text with two 'new line' characters at the beginning (maybe with \"inner quotation text\" also)
Some text with two 'new line' characters at the beginning (maybe with &qout;inner quotation text&qout; also)"}}
]}
私はこの結果を得ることができました:
{"data":
[{"Column 1":"outter quotation text and \"inner quotation text\""},
{"Column 2":"Some text with two 'new line' characters at the beginning (maybe with \"inner quotation text\" also)"}}
]}