![](/img/trans.png)
[英]Remove attributes from xml using xslt 1.0 and make it values comma separated
[英]Selecting the unique values from multiple attributes in an XML document using XSLT 1.0
我有以下XML:
<League>
<Week Date="26/04/2010 19:00">
<Fixture Id="542" HomeTeamId="371" HomeTeam="London Raiders Green" AwayTeamId="13" AwayTeam="Richmond Swingers" />
<Fixture Id="543" HomeTeamId="45" HomeTeam="Spartans" AwayTeamId="15" AwayTeam="Panthers" />
<Fixture Id="544" HomeTeamId="370" HomeTeam="Fat Cats" AwayTeamId="381" AwayTeam="London Raiders Orange" />
</Week>
<Week Date="27/04/2010 19:00">
<Fixture Id="548" HomeTeamId="3" HomeTeam="The Mob" AwayTeamId="81" AwayTeam="London Raiders Red" />
<Fixture Id="549" HomeTeamId="373" HomeTeam="Intellect" AwayTeamId="83" AwayTeam="Tornadoes" />
</Week>
</League>
我想要做的是獲取該XML中所有Team ID的唯一列表,但問題是團隊ID可以出現在HomeTeamId
中,也可以出現在fixture節點中的AwayTeamId
屬性中。 所以我很難使用標准的分組方法( 使用Muenchian方法分組或通過檢查前面的兄弟選擇唯一的節點 )。
我可以通過這種方式獲得所有ID的列表:
<xsl:for-each select="//Fixture/@HomeTeamId | //Fixture/@AwayTeamId">
<xsl:sort select="."/>
<xsl:value-of select="."/><br/>
</xsl:for-each>
但是當然當團隊出現在多個燈具中時,他們的id會使用上面的for-each多次輸出。
我的最終目標是輸出由每個團隊分組的燈具列表,但我在這里與XSLT斗爭 - 它讓我的大腦受傷......有人能指出我正確的方向嗎?
使用Muenchian分組應該不是問題:
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output indent="yes"/>
<xsl:key name="k1" match="Fixture/@HomeTeamId | Fixture/@AwayTeamId" use="."/>
<xsl:template match="/">
<html>
<head>
<body>
<xsl:for-each select="(//Fixture/@HomeTeamId | //Fixture/@AwayTeamId)[generate-id() = generate-id(key('k1', .)[1])]">
<xsl:sort select="." data-type="number"/>
<xsl:value-of select="."/>
<br/>
</xsl:for-each>
</body>
</head>
</html>
</xsl:template>
</xsl:stylesheet>
我不會使用for-each而是使用apply-templates,但是因為你已經在樣本中使用了for-each,所以我保留了它以顯示如何使用Muenchian分組。
即使它們的值屬於任意數量的不同命名屬性,此轉換也會生成唯一的團隊ID :
<xsl:stylesheet version="1.0"
xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:my="my:my" exclude-result-prefixes="my">
<xsl:output omit-xml-declaration="yes" indent="yes"/>
<xsl:key name="kTeamById"
match="@*[name()=document('')/*/my:teamIdNames/*]" use="."/>
<my:teamIdNames>
<name>HomeTeamId</name>
<name>AwayTeamId</name>
</my:teamIdNames>
<xsl:variable name="vAttrNames" select=
"document('')/*/my:teamIdNames/*"/>
<xsl:template match="/">
<xsl:apply-templates select=
"//Fixture/@*[name()=$vAttrNames]"/>
</xsl:template>
<xsl:template match=
"@*[name()=document('')/*/my:teamIdNames/*]
[generate-id()
=
generate-id(key('kTeamById', .)[1])
]
">
<xsl:value-of select="."/><br />
</xsl:template>
</xsl:stylesheet>
當此轉換應用於提供的XML文檔時:
<League>
<Week Date="26/04/2010 19:00">
<Fixture Id="542" HomeTeamId="371"
HomeTeam="London Raiders Green"
AwayTeamId="13" AwayTeam="Richmond Swingers"/>
<Fixture Id="543" HomeTeamId="45"
HomeTeam="Spartans" AwayTeamId="15"
AwayTeam="Panthers"/>
<Fixture Id="544" HomeTeamId="370"
HomeTeam="Fat Cats" AwayTeamId="381"
AwayTeam="London Raiders Orange" />
</Week>
<Week Date="27/04/2010 19:00">
<Fixture Id="548" HomeTeamId="3"
HomeTeam="The Mob" AwayTeamId="81"
AwayTeam="London Raiders Red"/>
<Fixture Id="549" HomeTeamId="373"
HomeTeam="Intellect" AwayTeamId="83"
AwayTeam="Tornadoes"/>
</Week>
</League>
產生了想要的結果 :
371<br/>13<br/>45<br/>15<br/>370<br/>381<br/>3<br/>81<br/>373<br/>83<br/>
請注意 :
此解決方案不假設團隊的ID來源僅來自名為HomeTeamId
和AwayTeamId
的屬性。
實際上,可以使用任何變量名稱集 (並包含在單獨的文檔中),因此這是一個非常強大的通用解決方案。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.