我已经用于测试案例设置以下数据
<?xml version="1.0" encoding="UTF-8"?>
<STUDENTS_LIST dateGenerated="2014-01-01">
<STUDENTS>
<MALE>
<STUDENT_ID>10000</STUDENT_ID>
<F_NAME>REGGIE</F_NAME>
<M_NAME/>
<L_NAME>MILLER</L_NAME>
<DOB>
<YEAR>1980</YEAR>
</DOB>
<STUDENT_TYPE>MORNING</STUDENT_TYPE>
<STUDENT_REF>BLUE</STUDENT_REF>
<JOIN_DATE>04-20-2000</JOIN_DATE>
<NOTES/>
<FATHER_NAME>
<NAME>MILLER A</NAME>
</FATHER_NAME>
<MOTHER_NAME>
<NAME>MILLER B</NAME>
</MOTHER_NAME>
<REFRESH_DATE>04-14-2014</REFRESH_DATE>
<CORE_SUBJECTS>
<SUBJECT_A>CALCULUS A</SUBJECT_A>
<SUBJECT_B>CALCULUS B</SUBJECT_B>
<SUBJECT_C>PERFORMING ARTS</SUBJECT_C>
</CORE_SUBJECTS>
<OPT_SUBJECTS>
<SUBJECT_A>AMERICAN HISTORY</SUBJECT_A>
<SUBJECT_B/>
<SUBJECT_C/>
</OPT_SUBJECTS>
<STUDENT_KEY>ABC10000-1</STUDENT_KEY>
<STUDENT_KEY_CREATION_DATE>04-20-2000</STUDENT_KEY_CREATION_DATE>
</MALE>
<FEMALE>
<STUDENT_ID>10001</STUDENT_ID>
<F_NAME>REGINA</F_NAME>
<M_NAME/>
<L_NAME>MOON</L_NAME>
<DOB>
<YEAR>1980</YEAR>
</DOB>
<STUDENT_TYPE>MORNING</STUDENT_TYPE>
<STUDENT_REF>BLUE</STUDENT_REF>
<JOIN_DATE>04-20-2000</JOIN_DATE>
<NOTES/>
<FATHER_NAME>
<NAME>MOON A</NAME>
</FATHER_NAME>
<MOTHER_NAME>
<NAME>MOON B</NAME>
</MOTHER_NAME>
<REFRESH_DATE>04-14-2014</REFRESH_DATE>
<CORE_SUBJECTS>
<SUBJECT_A>CALCULUS A</SUBJECT_A>
<SUBJECT_B>CALCULUS B</SUBJECT_B>
<SUBJECT_C>PERFORMING ARTS</SUBJECT_C>
</CORE_SUBJECTS>
<OPT_SUBJECTS>
<SUBJECT_A>AMERICAN HISTORY</SUBJECT_A>
<SUBJECT_B/>
<SUBJECT_C/>
</OPT_SUBJECTS>
<STUDENT_KEY>ABC10000-1</STUDENT_KEY>
<STUDENT_KEY_CREATION_DATE>04-20-2000</STUDENT_KEY_CREATION_DATE>
</FEMALE>
</STUDENTS>
</STUDENTS_LIST>
需要被转换为下面的XML使用XSLT
<?xml version="1.0" encoding="UTF-8"?>
<classified date="2014-01-01">
<students>
<student>
<student_id>10000</student_id>
<fname>REGGIE</fname>
<mname/>
<lname>MILLER</lname>
<sex>male</sex>
<data>student_type: MORNING, student_ref: BLUE, father_name: MILLER A,
mother_name: MILLER B, core_subjects : CALCULUS A, CALCULUS B, PERFORMING ARTS,
opt_subjects: AMERICAN HISTORY, student_key: ABC10000-1, student_key_creation_date:
04-20-2000, rec_refresh_date: 04-14-2014 </data>
<dob>
<year>1980</year>
</dob>
<joindate>04-20-2000</joindate>
</student>
<student>
<student_id>10001</student_id>
<fname>REGINA</fname>
<mname/>
<lname>MOON</lname>
<sex>female</sex>
<notes>student_type: MORNING, student_ref: BLUE, father_name: MOON A,
mother_name: MOON B, core_subjects : CALCULUS A, CALCULUS B, PERFORMING ARTS,
opt_subjects: AMERICAN HISTORY, student_key: ABC10000-1, student_key_creation_date:
04-20-2000, rec_refresh_date: 04-14-2014 </notes>
<dob>
<year>1980</year>
</dob>
<joindate>04-20-2000</joindate>
</student>
</students>
</classified>
我用@Joel M. Lamsen响应我的其他问题之一提供了以下XSLT。
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:strip-space elements="*"/>
<xsl:output indent="yes"/>
<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>
<xsl:template match="STUDENT_TYPE|STUDENT_REF|FATHER_NAME|MOTHER_NAME|STUDENT_KEY|STUDENT_KEY_CREATION_DATE">
<xsl:value-of select="concat(name(), ': ', .)"/><xsl:text>
</xsl:text>
</xsl:template>
<xsl:template match="NOTES"/>
<xsl:template match="REFRESH_DATE">
<xsl:value-of select="concat('REC_REFRESH_DATE', ': ', .)"/><xsl:text>
</xsl:text>
</xsl:template>
<xsl:template match="CORE_SUBJECTS|OPT_SUBJECTS">
<xsl:value-of select="concat(name(), ': ')"/>
<xsl:for-each select="*[.!='']">
<xsl:choose>
<xsl:when test="position() != last()">
<xsl:value-of select="."/>
<xsl:text>, </xsl:text>
</xsl:when>
<xsl:otherwise>
<xsl:value-of select="."/>
</xsl:otherwise>
</xsl:choose>
</xsl:for-each>
<xsl:text>
</xsl:text>
</xsl:template>
<xsl:template match="STUDENT">
<xsl:copy>
<xsl:apply-templates select="STUDENT_ID|F_NAME|M_NAME|L_NAME|NOTES|DOB"/>
<NOTES>
<xsl:text>
</xsl:text>
<xsl:apply-templates select="STUDENT_TYPE"/>
<xsl:apply-templates select="STUDENT_REF"/>
<xsl:apply-templates select="FATHER_NAME"/>
<xsl:apply-templates select="MOTHER_NAME"/>
<xsl:apply-templates select="CORE_SUBJECTS"/>
<xsl:apply-templates select="OPT_SUBJECTS"/>
<xsl:apply-templates select="STUDENT_KEY"/>
<xsl:apply-templates select="STUDENT_KEY_CREATION_DATE"/>
<xsl:apply-templates select="REFRESH_DATE"/>
</NOTES>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
所转换的需要是在精确映射顺序,需要对阳/阴基础进行排序。
在这方面的任何帮助,将不胜感激。
前面的例子已经得到解决。
至于雷吉。