【发布时间】:2019-11-06 05:27:42
【问题描述】:
这是我的 XML:
<?xml version="1.0" encoding="utf-8"?>
<records>
<CompanyCode>12345</CompanyCode>
<FirstName>Dan<FirstName>
<LastName>Haggerty<LastName>
<TeamMemberRole>CS Director<TeamMemberRole>
</records>
<records>
<CompanyCode>12345</CompanyCode>
<FirstName>And<FirstName>
<LastName>Onemore<LastName>
<TeamMemberRole>CS Director<TeamMemberRole>
</records>
<records>
<CompanyCode>12345</CompanyCode>
<FirstName>And<FirstName>
<LastName>Twomore<LastName>
<TeamMemberRole>DifferentRole<TeamMemberRole>
</records>
<records>
<CompanyCode>54321</CompanyCode>
<FirstName>And<FirstName>
<LastName>Twomore<LastName>
<TeamMemberRole>DifferentRole<TeamMemberRole>
</records>
这是我需要的输出:
<records>
<Company>
<CompanyCode>12345</CompanyCode>
<Role>
<TeamMemberRole>CS Director<TeamMemberRole>
<FirstName>Dan<FirstName>
<LastName>Haggerty<LastName>
<FirstName>And<FirstName>
<LastName>Onemore<LastName>
</Role>
<Role>
<TeamMemberRole>DifferentRole<TeamMemberRole>
<FirstName>And<FirstName>
<LastName>Twomore<LastName>
</Role>
</Company>
<Company>
<CompanyCode>54321</CompanyCode>
<Role>
<TeamMemberRole>DifferentRole<TeamMemberRole>
<FirstName>And<FirstName>
<LastName>Twomore<LastName>
</Role>
</Company>
</records>
我当前的 XSL:
<?xml version="1.0" encoding="utf-8"?>
<xsl:output method="xml" indent="yes"/>
<xsl:template match="/">
<xsl:element name="records">
<xsl:for-each-group select="/records" group-by="CompanyCode">
<xsl:element name="Company">
<xsl:value-of select="CompanyCode"/>
<xsl:for-each-group select="current-group()" group-by ="TeamMemberRole">
<xsl: element name "role">
<Role><xsl:value-of select="TeamMemberRole"/><Role>
<FirstName><xsl:value-of select="FirstName"/><FirstName>
<LastName><xsl:value-of select="LastName"/><LastName>
</xsl:element>
</xsl:for-each-group>
</xsl:element>
</xsl:for-each-group>
</xsl:element>
我当前的输出:
<Company>
<CompanyCode>12345</wd:CustomerId>
<Role>
<wd:Role>CS Director</wd:Role>
<wd:FirstName>Dan</wd:FirstName>
<wd:LastName>Haggerty</wd:LastName>
<Role>
<Role>
<Role>DifferentRole</wd:Role>
<wd:FirstName>and</wd:FirstName>
<wd:LastName>twomore</wd:LastName>
<role>
<Company>
<Company>
<CompanyCode>54321</wd:CustomerId>
<Role>
<wd:Role>DifferentRole</wd:Role>
<wd:FirstName>and</wd:FirstName>
<wd:LastName>twomore</wd:LastName>
<Role>
<records>
请不要我的语法错误。我更关心分组逻辑。如果您在当前输出中看到,对于第一个公司,只有一个名称出现,而不是第一个角色的两个名称。请帮忙。(信息:一个公司可以有很多人担任相同的角色,并且所有公司的角色名称都相同。)
【问题讨论】:
-
Kumar Pidikti 您的输入格式不正确请检查输入。
-
@Sandy 请不要介意语法错误。我担心分组逻辑。请查看我当前的输出和所需的输出。进一步按角色分组时正在跳过记录。
-
您确定需要两次 FirstName 和 LastName 所需的输出第一个角色位置吗?
-
@ManojKumarPidikiti 您的“语法错误”使我们无法使用您的代码重现您的问题 - 从而浪费了任何试图帮助您的人的时间。
-
@Sandy 这不是两次。在同一公司担任相同职务的两个人的名字和姓氏。
标签: xml xslt xslt-2.0 xslt-grouping