2

我发现这篇关于替换给定元素的值的现有帖子,但我需要进一步满足我的要求,因为我需要用另一个字符替换第一个字符。这是我找到的帖子:change value of element by xquery

源 XML:

<?xml version="1.0" encoding="UTF-8"?>
<category>
    <catid>1</catid>
    <cattext>sport</cattext>
</category>

使用这个 Xquery:

declare namespace local = "http://example.org";
declare function local:copy-replace($element as element()) {
  if ($element/self::cattext)
  then <cattext>art</cattext>
  else element {node-name($element)}
               {$element/@*,
                for $child in $element/node()
                return if ($child instance of element())
                       then local:copy-replace($child)
                       else $child
               }
};
local:copy-replace(/*)

给出这个输出:

<?xml version="1.0" encoding="UTF-8"?>
<category>
    <catid>1</catid>
    <cattext>art</cattext>
</category>

我对 Xquery 的了解才刚刚开始增长。如何将上面的 Xquery 更改为仅更改第一个字符,以便获得以下输出:

<?xml version="1.0" encoding="UTF-8"?>
<category>
    <catid>1</catid>
    <cattext>9port</cattext>
</category>
4

1 回答 1

3

使用substring()函数

declare namespace local = "http://example.org";
declare function local:copy-replace($element as element()) {
  if ($element/self::cattext)
  then <cattext>9{substring($element,2)}</cattext>
  else element {node-name($element)}
               {$element/@*,
                for $child in $element/node()
                return if ($child instance of element())
                       then local:copy-replace($child)
                       else $child
               }
};
local:copy-replace(/*)

当此查询应用于提供的 XML 文档时:

<category>
    <catid>1</catid>
    <cattext>sport</cattext>
</category>

产生了想要的正确结果:

<category>
    <catid>1</catid>
    <cattext>9port</cattext>
</category>

使用 XSLT 进行相同的转换要容易得多:

<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
 <xsl:output omit-xml-declaration="yes" indent="yes"/>
 <xsl:strip-space elements="*"/>

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

 <xsl:template match="cattext/text()">
  <xsl:text>9</xsl:text><xsl:value-of select="substring(., 2)"/>
 </xsl:template>
</xsl:stylesheet>

当此转换应用于同一个 XML 文档(上图)时,再次产生所需的正确结果

<category>
   <catid>1</catid>
   <cattext>9port</cattext>
</category>
于 2012-08-02T03:05:36.580 回答