簡體   English   中英

使用XSLT根據幾個子元素對XML進行排序

[英]Sorting XML based on several sub-elements using XSLT

我正在嘗試根據一些子元素對一些XML進行排序(使用XSLT),並將結果作為XML返回。 我知道這可能並不困難,但這是我第一次使用XSLT,這給我帶來了一些麻煩。 這是XML:

<root>
  <subject>
    <courseSubjectHeader>
        <subjectCode>B</subjectCode>
        <subjectName>text</subjectName>
        <unit>text</unit>
        <faculty>text</faculty>
    </courseSubjectHeader>
    <course>
      <crsLevel>text</crsLevel>
      <subjectAndNumber>B 200</subjectAndNumber>
      <units>3.0</units>
      <hours>3-0</hours>
    </course>
    <course>
      <crsLevel>text</crsLevel>
      <subjectAndNumber>B 100</subjectAndNumber>
      <units>3.0</units>
      <hours>3-0</hours>
    </course>
  </subject>
  <subject>
    <courseSubjectHeader>
        <subjectCode>C</subjectCode>
        <subjectName>text</subjectName>
        <unit>text</unit>
        <faculty>text</faculty>
    </courseSubjectHeader>
    <course>
      <crsLevel>text</crsLevel>
      <subjectAndNumber>C 300</subjectAndNumber>
      <units>3.0</units>
      <hours>3-0</hours>
    </course>
    <course>
      <crsLevel>text</crsLevel>
      <subjectAndNumber>C 100</subjectAndNumber>
      <units>3.0</units>
      <hours>3-0</hours>
    </course>
  </subject>
  <subject>
    <courseSubjectHeader>
        <subjectCode>A</subjectCode>
        <subjectName>text</subjectName>
        <unit>text</unit>
        <faculty>text</faculty>
    </courseSubjectHeader>
    <course>
      <crsLevel>text</crsLevel>
      <subjectAndNumber>A 300</subjectAndNumber>
      <units>3.0</units>
      <hours>3-0</hours>
    </course>
    <course>
      <crsLevel>text</crsLevel>
      <subjectAndNumber>A 200</subjectAndNumber>
      <units>3.0</units>
      <hours>3-0</hours>
    </course>
  </subject>
</root>

我想按“ subjectCode”子元素對“ subject”進行排序,並按“ subjectAndNumber”子元素對每個主題中的所有課程進行排序。 因此,生成的XML將是...

<root>
  <subject>
    <courseSubjectHeader>
        <subjectCode>A</subjectCode>
        <subjectName>text</subjectName>
        <unit>text</unit>
        <faculty>text</faculty>
    </courseSubjectHeader>
    <course>
      <crsLevel>text</crsLevel>
      <subjectAndNumber>A 200</subjectAndNumber>
      <units>3.0</units>
      <hours>3-0</hours>
    </course>
    <course>
      <crsLevel>text</crsLevel>
      <subjectAndNumber>A 300</subjectAndNumber>
      <units>3.0</units>
      <hours>3-0</hours>
    </course>
  </subject>
  <subject>
    <courseSubjectHeader>
        <subjectCode>B</subjectCode>
        <subjectName>text</subjectName>
        <unit>text</unit>
        <faculty>text</faculty>
    </courseSubjectHeader>
    <course>
      <crsLevel>text</crsLevel>
      <subjectAndNumber>B 100</subjectAndNumber>
      <units>3.0</units>
      <hours>3-0</hours>
    </course>
    <course>
      <crsLevel>text</crsLevel>
      <subjectAndNumber>B 200</subjectAndNumber>
      <units>3.0</units>
      <hours>3-0</hours>
    </course>
  </subject>
  <subject>
    <courseSubjectHeader>
        <subjectCode>C</subjectCode>
        <subjectName>text</subjectName>
        <unit>text</unit>
        <faculty>text</faculty>
    </courseSubjectHeader>
    <course>
      <crsLevel>text</crsLevel>
      <subjectAndNumber>C 100</subjectAndNumber>
      <units>3.0</units>
      <hours>3-0</hours>
    </course>
    <course>
      <crsLevel>text</crsLevel>
      <subjectAndNumber>C 300</subjectAndNumber>
      <units>3.0</units>
      <hours>3-0</hours>
    </course>
  </subject>
</root>

最后,這是我對XSLT的嘗試(非常糟糕):

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0"
     xmlns:xsl="http://www.w3.org/1999/ /Transform">

    <xsl:output method="xml" indent="yes"/>
    <xsl:strip-space elements="*"/>

    <xsl:template match="@*|node()">
        <xsl:copy>
            <xsl:apply-templates select="@*|node()"/>
        </xsl:copy>
    </xsl:template>

    <xsl:template match="/">
        <xsl:copy>
            <xsl:apply-templates select="subject">
                <xsl:sort select="subjectCode"/>
            </xsl:apply-templates>
        </xsl:copy>
    </xsl:template>

    <xsl:template match="subject">
        <xsl:copy>
            <xsl:apply-templates select="course">
                <xsl:sort select="subjectAndNumber"/>
            </xsl:apply-templates>
        </xsl:copy>
    </xsl:template>

</xsl:stylesheet>

任何幫助將不勝感激,謝謝!

您只有幾個小錯誤-比較:

<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" indent="yes"/>
<xsl:strip-space elements="*"/>

<xsl:template match="@*|node()">
    <xsl:copy>
        <xsl:apply-templates select="@*|node()"/>
    </xsl:copy>
</xsl:template>

<xsl:template match="/*">
    <xsl:copy>
        <xsl:apply-templates select="subject">
            <xsl:sort select="courseSubjectHeader/subjectCode"/>
        </xsl:apply-templates>
    </xsl:copy>
</xsl:template>

<xsl:template match="subject">
    <xsl:copy>
        <xsl:copy-of select="courseSubjectHeader"/>
        <xsl:apply-templates select="course">
            <xsl:sort select="subjectAndNumber"/>
        </xsl:apply-templates>
    </xsl:copy>
</xsl:template>

</xsl:stylesheet>

注意 :您最嚴重的錯誤是: xmlns:xsl="http://www.w3.org/1999/ /Transform" 如果您沒有正確聲明XSLT命名空間,則您的文檔根本不是樣式表。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM