아래 XML을 XSLT를 사용하여 변환해야합니다.다중 루프가있는 XSLT 변환
입력 XML은 XSLT가 = "페이지 폭"attrQualMany 내부 attrGroupMany = 각 행 "pagetype에"뿐만 아니라, 내부 루프 반복한다
<document>
<item>
<ID>1000909090</ID>
<flex>
<attrGroupMany name="pageinfo">
<row>
<attrQualMany name="pageinput">
<value qual="en">User Intake</value>
</attrQualMany>
<attrGroupMany name="pagetype">
<row>
<attr name="pagemeasure">EXACT</attr>
<attrQualMany name="pagecontain">
<value qual="GR">12</value>
</attrQualMany>
</row>
<row>
<attr name="pagemeasure">EXACT</attr>
<attrQualMany name="pagecontain">
<value qual="JH">13</value>
</attrQualMany>
</row>
</attrGroupMany>
<attr name="pagestate">PREPARED</attr>
<attrQualMany name="pagewidth">
<value qual="OZ">10</value>
<value qual="AB">11</value>
</attrQualMany>
</row>
</attrGroupMany>
</flex>
</item>
</document>
이다. 그래서 그것은 4 * 2 * 2 회 루프가됩니다.
출력은
<xsl:value-of select="concat('PAGEDETAILSINFO','-',ancestor::item/id,../../attr[@name='pagestate'], '-', pagewidthValue ,'-', pagewidthuom, '-', attr[@name='pagemeasure'] , '-',pagecontainValue, '-', pagecontainUOM )"/>
의 CONCAT해야하며, 예상 출력은
<?xml version="1.0" encoding="UTF-8"?>
<CatalogItem>
<RelationshipData>
<Relationship>
<RelationType>PAGEDETAILSINFO</RelationType>
<RelatedItems count="4">
<RelatedItem referenceKey="PAGEDETAILSINFO-1000909090-PREPARED-10-OZ-EXACT-12-GR" />
<RelatedItem referenceKey="PAGEDETAILSINFO-1000909090-PREPARED-10-OZ-EXACT-13-JH" />
<RelatedItem referenceKey="PAGEDETAILSINFO-1000909090-PREPARED-11-AB-EXACT-12-GR" />
<RelatedItem referenceKey="PAGEDETAILSINFO-1000909090-PREPARED-11-AB-EXACT-13-JH" />
</RelatedItems>
</Relationship>
</RelationshipData>
</CatalogItem>
나는 내부와 내 XSLT 모두 외부 루프 수없는 생각이다. XSLT 아래에서 사용하고 있습니다.
무엇을 그룹화해야합니까? 그게 필요한 것 같지 않니? – Tomalak
그럼 그룹화하지 않고 어떻게 할 수 있습니까? – Victor
그건 질문이 아닙니다. 그룹화가 필요합니까? – Tomalak