Xml 您好,我有一些员工记录,需要按公司分组,并按团队成员角色进行拆分
这是我的XML:Xml 您好,我有一些员工记录,需要按公司分组,并按团队成员角色进行拆分,xml,xslt,xslt-2.0,xslt-grouping,Xml,Xslt,Xslt 2.0,Xslt Grouping,这是我的XML: <?xml version="1.0" encoding="utf-8"?> <records> <CompanyCode>12345</CompanyCode> <FirstName>Dan<FirstName> <LastName>Haggerty<LastName> <TeamMemberRole>CS Director<TeamMemberRole>
<?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>
12345
丹
哈格蒂
政务司司长
12345
及
再
政务司司长
12345
及
两个以上
微分管
54321
及
两个以上
微分管
这是我所需的输出:
<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>
12345
政务司司长
丹
哈格蒂
及
再
微分管
及
两个以上
54321
微分管
及
两个以上
我当前的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>
12345
政务司司长
丹
哈格蒂
微分管
和
两个以上
54321
微分管
和
两个以上
请不要忘记我的语法错误。我更关心分组逻辑。如果您在当前输出中看到,对于第一个公司,只有一个名称出现,而不是第一个角色的两个名称。请提供帮助。(信息:一家公司中可以有许多人担任相同的角色,并且所有公司中的角色名称都相同。)您可以尝试此代码
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="xml" omit-xml-declaration="yes" indent="yes"/>
<xsl:template match="root">
<records>
<xsl:for-each-group select="records" group-by="CompanyCode">
<Company>
<CompanyCode><xsl:value-of select="current-grouping-key()"/></CompanyCode>
<xsl:for-each-group select="current-group()" group-by="TeamMemberRole">
<Role>
<TeamMemberRole><xsl:value-of select="current-grouping-key()"/></TeamMemberRole>
<FirstName><xsl:value-of select="FirstName"/></FirstName>
<LastName><xsl:value-of select="LastName"/></LastName>
</Role>
</xsl:for-each-group>
</Company>
</xsl:for-each-group>
</records>
</xsl:template>
</xsl:stylesheet>
演示:您可以尝试此代码
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:xs="http://www.w3.org/2001/XMLSchema"
exclude-result-prefixes="xs"
version="2.0">
<xsl:output method="xml" omit-xml-declaration="yes" indent="yes"/>
<xsl:template match="root">
<records>
<xsl:for-each-group select="records" group-by="CompanyCode">
<Company>
<CompanyCode><xsl:value-of select="current-grouping-key()"/></CompanyCode>
<xsl:for-each-group select="current-group()" group-by="TeamMemberRole">
<Role>
<TeamMemberRole><xsl:value-of select="current-grouping-key()"/></TeamMemberRole>
<FirstName><xsl:value-of select="FirstName"/></FirstName>
<LastName><xsl:value-of select="LastName"/></LastName>
</Role>
</xsl:for-each-group>
</Company>
</xsl:for-each-group>
</records>
</xsl:template>
</xsl:stylesheet>
演示:Kumar Pidikti您的输入格式不正确,请检查输入。@Sandy请不要介意语法错误。我关心分组逻辑。请查看我的当前输出和所需输出。当进一步按角色分组时,将跳过一条记录。您确定要将所需的输出第一个角色位置两倍于FirstName和LastName吗?@ManojKumarPidikiti您的“语法错误”阻止我们使用您的代码重现您的问题-从而浪费任何试图帮助您的人的时间。@Sandy这不是两次。在同一家公司担任相同职务的两个人的名字和姓氏。Kumar Pidikti您的输入格式不正确,请检查输入。@Sandy请不要介意语法错误。我关心分组逻辑。请查看我的当前输出和所需输出。当进一步按角色分组时,将跳过一条记录。您确定要将所需的输出第一个角色位置两倍于FirstName和LastName吗?@ManojKumarPidikiti您的“语法错误”阻止我们使用您的代码重现您的问题-从而浪费任何试图帮助您的人的时间。@Sandy这不是两次。同一公司中具有相同角色的两个人的名字和姓氏。谢谢,通过打印每个当前组的值,问题得到解决。非常感谢。非常感谢您抽出时间。谢谢,通过打印每个当前组的值,问题就解决了。非常感谢。谢谢你抽出时间来做这件事。