Привет, у меня есть несколько рабочих записей, которые мне нужны, чтобы они были сгруппированы по компаниям и разбиты по ролям членов команды - PullRequest
1 голос
/ 06 ноября 2019

это мой 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>

Пожалуйста, не допускайте синтаксических ошибок. Меня больше волнует логика группировки. Если вы видите в текущем выводе, для 1-й компании появилось только одно имя вместо двух имен для первой роли. Пожалуйста, помогите. (Информация: В одной компании может быть много людей с одинаковой ролью, а названия ролей одинаковы во всех компаниях.)

1 Ответ

0 голосов
/ 06 ноября 2019

Вы можете попробовать этот код

    <?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>

DEMO: https://xsltfiddle.liberty -development.net / ej9EGcU / 4

...