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" />