2009-01-30 58 views
1

我有以下XMLXML排序

<fields> 
    <field position="4" tablename="Students" headername="First Name" fieldreference="FirstName" orderbydirection="ASC" /> 
    <field position="2" tablename="Students" headername="Last Name" fieldreference="LastName" orderbydirection="ASC" /> 
    <field position="3" tablename="Students" headername="Race" fieldreference="Race" orderbydirection="ASC" /> 
    <field position="1" tablename="Students" headername="Sex" fieldreference="Sex" orderbydirection="ASC" /> 
    <field position="5" tablename="Students" headername="State" fieldreference="State" orderbydirection="ASC" /> 
</fields> 

我想基于“位置”进行排序它

如何能不能做到?

提前致谢!

+0

什么语言? XSLT? – foson 2009-01-30 17:44:47

+0

使用什么? XSLT?一个bash脚本?魔法棒? – 2009-01-30 17:45:07

回答

1

这XSLT 1.0转化排序:

<xsl:stylesheet version="1.0" 
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> 
<xsl:output omit-xml-declaration="yes" indent="yes"/> 

<xsl:strip-space elements="*"/> 

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

    <xsl:template match="fields"> 
     <xsl:copy> 
     <xsl:apply-templates select="@*"/> 
     <xsl:apply-templates> 
      <xsl:sort select="@position" data-type="number"/> 
     </xsl:apply-templates> 
     </xsl:copy> 
    </xsl:template> 
</xsl:stylesheet> 

当所提供的XML文档施加:

<fields> 
    <field position="4" tablename="Students" headername="First Name" fieldreference="FirstName" orderbydirection="ASC" /> 
    <field position="2" tablename="Students" headername="Last Name" fieldreference="LastName" orderbydirection="ASC" /> 
    <field position="3" tablename="Students" headername="Race" fieldreference="Race" orderbydirection="ASC" /> 
    <field position="1" tablename="Students" headername="Sex" fieldreference="Sex" orderbydirection="ASC" /> 
    <field position="5" tablename="Students" headername="State" fieldreference="State" orderbydirection="ASC" /> 
</fields> 

产生想要的结果

<fields> 
    <field position="1" tablename="Students" headername="Sex" fieldreference="Sex" orderbydirection="ASC" /> 
    <field position="2" tablename="Students" headername="Last Name" fieldreference="LastName" orderbydirection="ASC" /> 
    <field position="3" tablename="Students" headername="Race" fieldreference="Race" orderbydirection="ASC" /> 
    <field position="4" tablename="Students" headername="First Name" fieldreference="FirstName" orderbydirection="ASC" /> 
    <field position="5" tablename="Students" headername="State" fieldreference="State" orderbydirection="ASC" /> 
</fields>