У меня есть XML-файл, в котором перечислены классы в рамках программы степени. Я создал XSLT (с помощью), который успешно создает группы классов под именем степени. Но клиент хочет третьего уровня, который идентифицирует выборные и недифференцируемые классы. Поле выборки указано с данными «Y», если оно является выборным, и «N», если это не так, или иначе «требование программы».Трехуровневая группа, использующая XSLT
Мне нужно добавить еще один уровень в XSLT, который группирует классы под заголовком «Требование к программе», если у него есть «N» в элементе <FlagElectives1>
.
Мне кажется, мне нужно создать другой ключ, основанный на этом элементе, справа, а затем создать шаблон, который создает заголовок xsl: text, который говорит либо: «Требование к программе», либо «Выбор программы», но я застрял. Раньше я никогда не делал трехуровневую группировку.
Вот мой XSLT:
<?xml version="1.0"?>
<!-- DWXMLSource="STX049 Catalog parsed.xml" -->
<!DOCTYPE xsl:stylesheet>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" indent="no"/>
<xsl:template match="/">
<CrystalReport>
<xsl:apply-templates/>
</CrystalReport>
</xsl:template>
<xsl:key name="degrees-by-title" match="CrystalReport/Group/Group/Group/Details" use="Section/ICCB1" />
<xsl:template match="CrystalReport/Group/Group/Group">
<Degree>
<xsl:for-each select="Details[count(. | key('degrees-by-title', Section/ICCB1)[1]) = 1]">
<xsl:sort select="Section/ACADPROGRAMSID1" />
<department>
<Degreetitle>
<xsl:apply-templates select="Section/ACPGDEGREE1" />
</Degreetitle>
<Certtitle>
<xsl:apply-templates select="Section/CCD11" />
</Certtitle>
<DegreeDesc>
<xsl:value-of select="Section/ACPGCOMMENTS1"/>
</DegreeDesc>
<ICCBcode>
<xsl:value-of select="Section/ICCB1"/>
</ICCBcode>
<ProgramID>
<xsl:value-of select="Section/ACADPROGRAMSID1"/>
</ProgramID>
<xsl:for-each select="key('degrees-by-title', Section/ICCB1)">
<xsl:sort select="Section/FlagElectives1" order="ascending" />
<xsl:sort select="Section/DEPARTMENT11" />
<xsl:sort select="Section/CRSNO1" />
<Details>
<class>
<deptname>
<xsl:value-of select="Section/DEPARTMENT11"/>
</deptname>
<courseno>
<xsl:value-of select="Section/CRSNO1"/>
</courseno>
<classname>
<xsl:value-of select="Section/CRSTITLE1"/>
</classname>
<classcredit>
<xsl:value-of select="Section/CRSMINCRED1"/>
</classcredit>
<Elective>
<xsl:value-of select="Section/FlagElectives1" />
</Elective>
</class>
</Details>
</xsl:for-each>
</department>
</xsl:for-each>
</Degree>
</xsl:template>
<xsl:template match="Section/ACPGDEGREE1[child::node()]">
<xsl:value-of select="."/>
<xsl:text> DEGREE</xsl:text>
</xsl:template>
<xsl:template match="Section/CCD11[child::node()]">
<xsl:text> CERTIFICATE</xsl:text>
</xsl:template>
</xsl:stylesheet>
Вот структура моего XML:
<?xml version="1.0" encoding="UTF-8"?>
<CrystalReport>
<Group Level="1">
<Group Level="2">
<Group Level="3">
<Details>
<Section>
<ACPGDEGREE1>AAS</ACPGDEGREE1>
<CCD11/>
<ACPGCOMMENTS1>The Accounting program</ACPGCOMMENTS1>
<ICCB1>3203</ICCB1>
<ACADPROGRAMSID1>ACCOU.AAS</ACADPROGRAMSID1>
<CRSNO1>1110</CRSNO1>
<ACRBPRINTEDSPEC1/>
<ACPGHOMELANGNOTREQDRSN1>General Education</ACPGHOMELANGNOTREQDRSN1>
<CRSMINCRED1>2</CRSMINCRED1>
<ACPGAREAOFSTUDY1>Accounting</ACPGAREAOFSTUDY1>
<CRSTITLE1>Using Computers: An Introduction</CRSTITLE1>
<DEPARTMENT11>ACCOU</DEPARTMENT11>
<CRSSUBJECT1>CIS</CRSSUBJECT1>
<ACRBLABEL1>CIS REQUIREMENT</ACRBLABEL1>
<CRSMAXCRED1/>
<FlagElectives1>N</FlagElectives1>
</Section>
</Details>
<Details>
<Section>
<ACPGDEGREE1>AAS</ACPGDEGREE1>
<CCD11/>
<ACPGCOMMENTS1>The Accounting program</ACPGCOMMENTS1>
<ICCB1>3203</ICCB1>
<ACADPROGRAMSID1>ACCOU.AAS</ACADPROGRAMSID1>
<CRSNO1>1150</CRSNO1>
<ACRBPRINTEDSPEC1/>
<ACPGHOMELANGNOTREQDRSN1>General Education</ACPGHOMELANGNOTREQDRSN1>
<CRSMINCRED1>3</CRSMINCRED1>
<ACPGAREAOFSTUDY1>Accounting</ACPGAREAOFSTUDY1>
<CRSTITLE1>Intro to Computer</CRSTITLE1>
<DEPARTMENT11>ACCOU</DEPARTMENT11>
<CRSSUBJECT1>CIS</CRSSUBJECT1>
<ACRBLABEL1>CIS</ACRBLABEL1>
<CRSMAXCRED1/>
<FlagElectives1>Y</FlagElectives1>
</Section>
</Details>
</Group>
</Group>
</Group>
</CrystalReport>
Первый уровень группировки должен быть основан на элементе <DEPARTMENT11>
. Название различных степеней и сертификатов находится в поле <ACPGAREAOFSTUDY1>
Уникальное поле второго уровня во всем этом <ACADPROGRAMSID1>
Здесь желаемый результат:
<CrystalReport>
<Degrees>
<!--group and repeat "Degrees" for-each based on element ACPGAREAOFSTUDY1-->
<areaofstudy>Accounting</areaofstudy>
<Degree>
<department>
<!--group and repeat "department" for-each based on element ICCB1-->
<Degreetitle>AAS DEGREE</Degreetitle>
<Certtitle />
<DegreeDesc>The Accounting program</DegreeDesc>
<ICCBcode>3203</ICCBcode>
<ProgramID>ACCOU.AAS</ProgramID>
<!--group and repeat "Details" for-each based on element ACADPROGRAMSID1 under titles "Program Requirement" or "Program Elective" based on element "FlagElectives1"-->
<h1>Program Requirements</h1>
<Details>
<class>
<deptname>ACCOU</deptname>
<courseno>1150</courseno>
<classname>Intro to Computer</classname>
<classcredit>3</classcredit>
<Elective>N</Elective>
</class>
</Details>
<h1>Program Electives</h1>
<Details>
<class>
<deptname>ACCOU</deptname>
<courseno>1110</courseno>
<classname>Using Computers: An Introduction</classname>
<classcredit>2</classcredit>
<Elective>Y</Elective>
</class>
</Details>
</department>
</Degree>
<Degree>
<department>
<Degreetitle>AAS DEGREE</Degreetitle>
<Certtitle />
<DegreeDesc>The Accounting program</DegreeDesc>
<ICCBcode>3203</ICCBcode>
<ProgramID>ACCOU.AAS</ProgramID>
<h1>Program Requirements</h1>
<Details>
<class>
<deptname>ACCOU</deptname>
<courseno>1150</courseno>
<classname>Intro to Computer</classname>
<classcredit>3</classcredit>
<Elective>Y</Elective>
</class>
</Details>
<h1>Program Electives</h1>
<Details>
<class>
<deptname>ACCOU</deptname>
<courseno>1110</courseno>
<classname>Using Computers: An Introduction</classname>
<classcredit>2</classcredit>
<Elective>N</Elective>
</class>
</Details>
</department>
</Degree>
</Degrees>
</CrystalReport>
Не могли бы вы привести нам пример того, как вы хотите, чтобы результат выглядел? – JLRishe
Я вижу, что вы открыли отдельный вопрос для последующего вопроса. Помог ли мой ответ здесь или в другом вопросе, который я ответил (о пространствах имен)? Если да, не могли бы вы назвать их ответами? – JLRishe
Вы обновили ответ на тот же код по другому вопросу? Я буду отмечать это как ответ, если вы это сделаете. Я открыл второй вопрос, потому что некоторые люди не допускают нескольких шагов в вопросах. Один вопрос -> один ответ. Но обновленный XSLT ближе к окончательному решению. –