xslt removnig结果前缀

时间:2016-06-30 11:12:47

标签: xslt prefixes

我有一个类似的文件:

<?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;

1 个答案:

答案 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>