我有一个xml数据源,如下所示:
<dsQueryResponse> <Department> <Rows> <Row dept="HR" state="NY" region="East"/> <Row dept="HR" state="NJ" region="East"/> <Row dept="SD" state="NY" region="East"/> <Row dept="MM" state="NY" region="East"/> <Row dept="SD" state="NJ" region="East"/> <Row dept="SD" state="CO" region="West"/> <Row dept="MM" state="CO" region="West"/> </Rows> </Department> </dsQueryResponse>
我的XSLT看起来像这样:
<?xml version="1.0" encoding="utf-8"?> <xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:msxsl="urn:schemas-microsoft-com:xslt" exclude-result-prefixes="msxsl"> <xsl:output method="html" indent="no"/> <xsl:decimal-format NaN=""/> <xsl:param name="DeptQS">East</xsl:param> <xsl:variable name="deptRows" select="/dsQueryResponse/Department/Rows/Row[@region = $DeptQS]"/> <xsl:template match="/"> <xsl:if test="count($deptRows) > 0"> <xsl:call-template name="deptList"/> </xsl:if> </xsl:template> <xsl:template name="deptList"> <xsl:for-each select="$deptRows"> <!-- process unique depts--> </xsl:for-each> </xsl:template> </xsl:stylesheet>
我希望将该地区的所有部门都写出来.我现在的代码将写出重复的部门.但是我怎么能只为该地区的部门写一次呢?
谢谢!
解决方法
对于XSLT 1.0,您可以使用“
Muenchian Method”.
您将创建一个键,通过@region和@dept值的组合来索引Row元素.
然后,您将获得该区域/部门组合的第一次出现(具有所需区域($DeptQS))并输出部门(部门).
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"> <xsl:output indent="yes" method="xml" omit-xml-declaration="yes"/> <xsl:strip-space elements="*"/> <xsl:key name="kDept" match="Department/Rows/Row" use="concat(@region,'|',@dept)"/> <xsl:param name="DeptQS">East</xsl:param> <xsl:template match="/*"> <xsl:for-each select="Department/Rows/Row[count(.|key('kDept',concat($DeptQS,@dept))[1])=1]"> <test>Current dept: <xsl:value-of select="@dept"/></test> </xsl:for-each> </xsl:template> </xsl:stylesheet>
这是使用输入XML的输出:
<test>Current dept: HR</test> <test>Current dept: SD</test> <test>Current dept: MM</test>
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。