Xml 明钦分组

Xml 明钦分组,xml,xslt,Xml,Xslt,我第一次尝试使用明钦语分组,但有一些问题。 我想我犯了一些逻辑错误,我不知道如何找到它。如果在输入文件转换中删除第一个块,可以正常工作,但现在不工作: Source <?xml version="1.0" encoding="utf-8"?> <ROOT xsi:schemaLocation="http://www.av.com/pu" Name="StaffManagers" xmlns:xsi="http://www.w3.org/2001/XMLSchema-insta

我第一次尝试使用明钦语分组,但有一些问题。 我想我犯了一些逻辑错误,我不知道如何找到它。如果在输入文件转换中删除第一个块,可以正常工作,但现在不工作:

 Source
<?xml version="1.0" encoding="utf-8"?>
<ROOT xsi:schemaLocation="http://www.av.com/pu" Name="StaffManagers" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://www.av.pu/pu">
    <Data>
        <Part>
            <ReportPart1>
                <Details>
                    <Detail BlokName="Accountant">
                        <Number>1.1.9</Number>
                        <Content>Y</Content>
                        <Id>CInfo</Id>
                        <Collection_Id>11.001.001.009.001</Collection_Id>
                    </Detail>
                    <Detail BlokName="Accountant" Id="CollEduEx">
                        <Number>1.1.9.1</Number>
                        <Content>College</Content>
                        <Suffix>NameEx</Suffix>
                        <Id>CollEduEx</Id>
                        <Collection_Id>11.001.001.009.001</Collection_Id>
                    </Detail>
                    <Detail BlokName="Accountant" Id="CollEduEx">
                        <Number>1.1.9.2</Number>
                        <Content>1 981</Content>
                        <Suffix>YEx</Suffix>
                        <Id>CollEduEx</Id>
                        <Collection_Id>11.001.001.009.001</Collection_Id>
                    </Detail>
                    <Detail BlokName="Accountant" Id="CollEduEx">
                        <Number>1.1.9.3</Number>
                        <Content>XX4793</Content>
                        <Suffix>DEx</Suffix>
                        <Id>CollEduEx</Id>
                        <Collection_Id>11.001.001.009.001</Collection_Id>
                    </Detail>
                    <Detail BlokName="Accountant" Id="CollEduEx">
                        <Number>1.1.9.4</Number>
                        <Content>Networks</Content>
                        <Suffix>SEx</Suffix>
                        <Id>CollEduEx</Id>
                        <Collection_Id>11.001.001.009.001</Collection_Id>
                    </Detail>
                    <Detail BlokName="Accountant" Id="CollEduEx">
                        <Number>1.1.9.5</Number>
                        <Content>Eng</Content>
                        <Suffix>QEx</Suffix>
                        <Id>CollEduEx</Id>
                        <Collection_Id>11.001.001.009.001</Collection_Id>
                    </Detail>
                    <Detail BlokName="Accountant" Id="CollEduEx">
                        <Number>1.1.9.1</Number>
                        <Content>Uni</Content>
                        <Suffix>NameEx</Suffix>
                        <Id>CollEduEx</Id>
                        <Collection_Id>11.001.001.009.002</Collection_Id>
                    </Detail>
                    <Detail BlokName="Accountant" Id="CollEduEx">
                        <Number>1.1.9.2</Number>
                        <Content>1 999</Content>
                        <Suffix>YEx</Suffix>
                        <Id>CollEduEx</Id>
                        <Collection_Id>11.001.001.009.002</Collection_Id>
                    </Detail>
                    <Detail BlokName="Accountant" Id="CollEduEx">
                        <Number>1.1.9.3</Number>
                        <Content>DFC12</Content>
                        <Suffix>DEx</Suffix>
                        <Id>CollEduEx</Id>
                        <Collection_Id>11.001.001.009.002</Collection_Id>
                    </Detail>
                    <Detail BlokName="Accountant" Id="CollEduEx">
                        <Number>1.1.9.4</Number>
                        <Content>Acciy</Content>
                        <Suffix>SEx</Suffix>
                        <Id>CollEduEx</Id>
                        <Collection_Id>11.001.001.009.002</Collection_Id>
                    </Detail>
                    <Detail BlokName="Accountant" Id="CollEduEx">
                        <Number>1.1.9.5</Number>
                        <Content>Eco</Content>
                        <Suffix>QEx</Suffix>
                        <Id>CollEduEx</Id>
                        <Collection_Id>11.001.001.009.002</Collection_Id>
                    </Detail>
                </Details>
            </ReportPart1>
        </Part>
    </Data>
</ROOT>
</i>
xsl

预期结果

<av:Part1 xmlns:av="http://www.av.pu/pu">
   <CollEduEx/>
   <av:CInfo>Y</av:CInfo>
   <CollEduEx>
      <EducationExecutive>
         <av:NameEx>College</av:NameEx>
         <av:YEx>1 981</av:YEx>
         <av:DEx>XX4793</av:DEx>
         <av:SEx>Networks</av:SEx>
         <av:QEx>Eng</av:QEx>
      </EducationExecutive>
      <EducationExecutive>
         <av:NameEx>Uni</av:NameEx>
         <av:YEx>1 999</av:YEx>
         <av:DEx>DFC12</av:DEx>
         <av:SEx>Acciy</av:SEx>
         <av:QEx>Eco</av:QEx>
      </EducationExecutive>
   </CollEduEx>
</av:Part1>

我已经有一段时间没有理解慕尼黑方法了

粗略地说,我对Muenchian方法的理解是,创建一种查找表。具有相同值的每个元素将具有相同的键值。因此,您可以将文档不同部分中的元素分组,方法是将它们的键与其类型中的第一个键进行比较。是这样吗?这有意义吗

我不确定我是否能完全解释或理解它。但是,如果您有:

<xsl:key name="Collection_Id" match="*" use="av:Collection_Id" />
将此更改为:

<xsl:key name="Collection_Id" match="av:Detail[@Id]" use="av:Collection_Id" />
似乎可以修复它。

如果我删除输入文件转换中的第一个块,工作正常,但现在不工作,那么确切的问题是什么?什么是工作好,现在不工作??
<xsl:key name="Collection_Id" match="av:Detail[@Id]" use="av:Collection_Id" />