我有一个类似的文件:
<?xml version='1.0' encoding='UTF-8'?>
<wd:Report_Data xmlns:wd="urn:com.workday.report/Business_Process_Transactions_-_Canceled__Rescinded_or_Corrected">
<wd:Report_Entry>
<wd:Worker wd:Descriptor="**** *****">
<wd:ID wd:type="WID">2b994449ed3b10ba7bc5d65f971ba4d4</wd:ID>
<wd:ID wd:type="Employee_ID">00083646</wd:ID>
</wd:Worker>
</wd:Report_Entry>
</wd:Report_Data>
我使用这个xslt来转换它:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="2.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:wd="urn:com.workday.report/Business_Process_Transactions_-_Canceled__Rescinded_or_Corrected"
exclude-result-prefixes="wd">
<xsl:output method="xml" indent="yes" omit-xml-declaration="yes"/>
<xsl:template match ="/">
<xsl:apply-templates select="wd:Report_Data/wd:Report_Entry/wd:Worker[@wd:Descriptor!='']" />
</xsl:template>
<xsl:template match="wd:Report_Data/wd:Report_Entry/wd:Worker[@wd:Descriptor!='']">
<wd:Instance_Reference>
<wd:ID>
<xsl:attribute name="wd:type">
<xsl:value-of select="wd:ID[@wd:type='Contingent_Worker_ID' or @wd:type='Employee_ID']/@wd:type"/>
</xsl:attribute>
<xsl:value-of select="wd:ID[@wd:type='Contingent_Worker_ID' or @wd:type='Employee_ID']"></xsl:value-of>
</wd:ID>
</wd:Instance_Reference>
</xsl:template>
</xsl:stylesheet>
它给了我:
<wd:Instance_Reference xmlns:wd="urn:com.workday.report/Business_Process_Transactions_-_Canceled__Rescinded_or_Corrected">
<wd:ID wd:type="Employee_ID">00083646</wd:ID>
</wd:Instance_Reference>
我想删除此元素:
的xmlns:WD =&#34;瓮:com.workday.report/Business_Process_Transactions _-_ Canceled__Rescinded_or_Corrected&#34;
答案 0 :(得分:1)
你没有名称空间声明的前缀。 但是如果你删除命名空间并留下这样的输出......
<Instance_Reference>
<ID type="Employee_ID">00083646</ID>
</Instance_Reference>
然后您需要做的就是创建输出元素而不排除前缀。在你的例子中,只需将最终模板设为chnage ..
<xsl:template match="wd:Report_Data/wd:Report_Entry/wd:Worker[@wd:Descriptor!='']">
<Instance_Reference>
<ID>
<xsl:attribute name="type">
<xsl:value-of select="wd:ID[@wd:type='Contingent_Worker_ID' or @wd:type='Employee_ID']/@wd:type"/>
</xsl:attribute>
<xsl:value-of select="wd:ID[@wd:type='Contingent_Worker_ID' or @wd:type='Employee_ID']"></xsl:value-of>
</ID>
</Instance_Reference>
</xsl:template>