如何使用 XSLT 替换名称空间中的元素?
How to use XSLT to replace an element that is in a namespace?
我需要使用 XSL 转换将 XML 中的元素替换为新元素。输入 XML 包含命名空间声明。我确实通过在 XSLT 中声明相同的名称空间并在模板中添加名称空间前缀来设法匹配该元素。但是我不能在同一个命名空间中插入新元素。
输入XML
<?xml version="1.0" encoding="utf-8"?>
<ledesxmlebilling2.1 xmlns="http://www.ledes.org/ledes21.xsd">
<firm>
<client>
<invoice>
<matter>
<tksum>
<tk_id>Sample ID</tk_id>
<tk_lname>Sample last name</tk_lname>
<tk_fname />
<tk_level>Sample level</tk_level>
<tk_rate>Sample rate</tk_rate>
</tksum>
</matter>
</invoice>
</client>
</firm>
</ledesxmlebilling2.1>
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" xmlns:ledes="http://www.ledes.org/ledes21.xsd" exclude-result-prefixes="msxsl">
<xsl:output method="xml" indent="yes"/>
<!-- identity template -->
<xsl:template match="@* | node()">
<xsl:copy>
<xsl:apply-templates select="@* | node()"/>
</xsl:copy>
</xsl:template>
<!-- tksum template -->
<xsl:template match="ledes:tksum">
<tksum>
<tk_id>New ID</tk_id>
<tk_lname>New last name</tk_lname>
<tk_fname />
<tk_level>New level</tk_level>
<tk_rate>New rate</tk_rate>
</tksum>
</xsl:template>
</xsl:stylesheet>
当前输出XML
<?xml version="1.0" encoding="utf-8"?>
<ledesxmlebilling2.1 xmlns="http://www.ledes.org/ledes21.xsd">
<firm>
<client>
<invoice>
<matter>
<tksum xmlns="" xmlns:ledes="http://www.ledes.org/ledes21.xsd">
<tk_id>New ID</tk_id>
<tk_lname>New last name</tk_lname>
<tk_fname />
<tk_level>New level</tk_level>
<tk_rate>New rate</tk_rate>
</tksum>
</matter>
</invoice>
</client>
</firm>
</ledesxmlebilling2.1>
期望输出XML
<?xml version="1.0" encoding="utf-8"?>
<ledesxmlebilling2.1 xmlns="http://www.ledes.org/ledes21.xsd">
<firm>
<client>
<invoice>
<matter>
<tksum>
<tk_id>New ID</tk_id>
<tk_lname>New last name</tk_lname>
<tk_fname />
<tk_level>New level</tk_level>
<tk_rate>New rate</tk_rate>
</tksum>
</matter>
</invoice>
</client>
</firm>
</ledesxmlebilling2.1>
我应该如何更改 XSLT 以获得所需的输出XML?
I cannot insert the new element in the same namespace.
其实很简单-试试看:
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:ledes="http://www.ledes.org/ledes21.xsd"
exclude-result-prefixes="ledes">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>
<!-- identity transform -->
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="ledes:tksum">
<tksum xmlns="http://www.ledes.org/ledes21.xsd">
<tk_id>New ID</tk_id>
<tk_lname>New last name</tk_lname>
<tk_fname />
<tk_level>New level</tk_level>
<tk_rate>New rate</tk_rate>
</tksum>
</xsl:template>
</xsl:stylesheet>
我需要使用 XSL 转换将 XML 中的元素替换为新元素。输入 XML 包含命名空间声明。我确实通过在 XSLT 中声明相同的名称空间并在模板中添加名称空间前缀来设法匹配该元素。但是我不能在同一个命名空间中插入新元素。
输入XML
<?xml version="1.0" encoding="utf-8"?>
<ledesxmlebilling2.1 xmlns="http://www.ledes.org/ledes21.xsd">
<firm>
<client>
<invoice>
<matter>
<tksum>
<tk_id>Sample ID</tk_id>
<tk_lname>Sample last name</tk_lname>
<tk_fname />
<tk_level>Sample level</tk_level>
<tk_rate>Sample rate</tk_rate>
</tksum>
</matter>
</invoice>
</client>
</firm>
</ledesxmlebilling2.1>
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" xmlns:ledes="http://www.ledes.org/ledes21.xsd" exclude-result-prefixes="msxsl">
<xsl:output method="xml" indent="yes"/>
<!-- identity template -->
<xsl:template match="@* | node()">
<xsl:copy>
<xsl:apply-templates select="@* | node()"/>
</xsl:copy>
</xsl:template>
<!-- tksum template -->
<xsl:template match="ledes:tksum">
<tksum>
<tk_id>New ID</tk_id>
<tk_lname>New last name</tk_lname>
<tk_fname />
<tk_level>New level</tk_level>
<tk_rate>New rate</tk_rate>
</tksum>
</xsl:template>
</xsl:stylesheet>
当前输出XML
<?xml version="1.0" encoding="utf-8"?>
<ledesxmlebilling2.1 xmlns="http://www.ledes.org/ledes21.xsd">
<firm>
<client>
<invoice>
<matter>
<tksum xmlns="" xmlns:ledes="http://www.ledes.org/ledes21.xsd">
<tk_id>New ID</tk_id>
<tk_lname>New last name</tk_lname>
<tk_fname />
<tk_level>New level</tk_level>
<tk_rate>New rate</tk_rate>
</tksum>
</matter>
</invoice>
</client>
</firm>
</ledesxmlebilling2.1>
期望输出XML
<?xml version="1.0" encoding="utf-8"?>
<ledesxmlebilling2.1 xmlns="http://www.ledes.org/ledes21.xsd">
<firm>
<client>
<invoice>
<matter>
<tksum>
<tk_id>New ID</tk_id>
<tk_lname>New last name</tk_lname>
<tk_fname />
<tk_level>New level</tk_level>
<tk_rate>New rate</tk_rate>
</tksum>
</matter>
</invoice>
</client>
</firm>
</ledesxmlebilling2.1>
我应该如何更改 XSLT 以获得所需的输出XML?
I cannot insert the new element in the same namespace.
其实很简单-试试看:
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:ledes="http://www.ledes.org/ledes21.xsd"
exclude-result-prefixes="ledes">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:strip-space elements="*"/>
<!-- identity transform -->
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="ledes:tksum">
<tksum xmlns="http://www.ledes.org/ledes21.xsd">
<tk_id>New ID</tk_id>
<tk_lname>New last name</tk_lname>
<tk_fname />
<tk_level>New level</tk_level>
<tk_rate>New rate</tk_rate>
</tksum>
</xsl:template>
</xsl:stylesheet>