XSLT-преобразование с повторяющимися элементами и родительским узлом - PullRequest
0 голосов
/ 18 мая 2018

Я пытаюсь преобразовать приведенный ниже xml в строки и столбцы.У Job_Classification_Group может быть много детей Job_Classifications.Мне нужно, чтобы Job_Classification_Group_ID был первым во всех строках, затем информация об этом Job_Classification_Group, а затем каждый Job_Classification_Reference_ID

Другими словами:

Job_Classification_Group_ID | wd:ID | wd: Effective_Date | wd: Job_Classification_Group_Name | wd: Location_Reference [2] | wd: Location_Reference [3] | wd: Location_Reference [4] | wd: Job_Classification_Data / Job_Classification_Reference_ID [1] Job_Classification_Group_ID: wd: ID: wd: ID: wd: ID: wd: ID: wd: w: w: | идентификатор |: Job_Classification_Group_Name | wd: Location_Reference [2] | wd: Location_Reference [3] | wd: Location_Reference [4] | wd: Job_Classification_Data / Job_Classification_Reference_ID [2]

<env:Envelope xmlns:env="http://schemas.xmlsoap.org/soap/envelope/">
   <env:Body>
      <wd:Get_Job_Classification_Groups_Response wd:version="v29.1" xmlns:wd="urn:com.workday/bsvc">
         <wd:Response_Filter>
            <wd:Page>3</wd:Page>
            <wd:Count>1</wd:Count>
         </wd:Response_Filter>
         <wd:Response_Group>
            <wd:Include_Reference>1</wd:Include_Reference>
            <wd:Include_Job_Classifications>1</wd:Include_Job_Classifications>
         </wd:Response_Group>
         <wd:Response_Results>
            <wd:Total_Results>21</wd:Total_Results>
            <wd:Total_Pages>21</wd:Total_Pages>
            <wd:Page_Results>1</wd:Page_Results>
            <wd:Page>3</wd:Page>
         </wd:Response_Results>
         <wd:Response_Data>
            <wd:Job_Classification_Group>
               <wd:Job_Classification_Group_Reference wd:Descriptor="Klassifikation der Berufe 2010 (KldB 2010)">
                  <wd:ID wd:type="WID">16d569ce573c01b6725820441e3b7049</wd:ID>
                  <wd:ID wd:type="Job_Classification_Group_ID">KldB2010_Germany</wd:ID>
               </wd:Job_Classification_Group_Reference>
               <wd:Job_Classification_Group_Name_Data>
                  <wd:Job_Classification_Group_Name>Klassifikation der Berufe 2010 (KldB 2010)</wd:Job_Classification_Group_Name>
               </wd:Job_Classification_Group_Name_Data>
               <wd:Job_Classification_Group_Data>
                  <wd:ID>KldB2010_Germany</wd:ID>
                  <wd:Effective_Date>2018-04-18-07:00</wd:Effective_Date>
                  <wd:Job_Classification_Group_Name>Klassifikation der Berufe 2010 (KldB 2010)</wd:Job_Classification_Group_Name>
                  <wd:Location_Reference wd:Descriptor="Germany">
                     <wd:ID wd:type="WID">dcc5b7608d8644b3a93716604e78e995</wd:ID>
                     <wd:ID wd:type="ISO_3166-1_Alpha-2_Code">DE</wd:ID>
                     <wd:ID wd:type="ISO_3166-1_Alpha-3_Code">DEU</wd:ID>
                     <wd:ID wd:type="ISO_3166-1_Numeric-3_Code">276</wd:ID>
                  </wd:Location_Reference>
                  <wd:Inactive>0</wd:Inactive>
                  <wd:Job_Classification>
                     <wd:Job_Classification_Reference wd:Descriptor="1 - Land-, Forst- und Tierwirtschaft und Gartenbau (Klassifikation der Berufe 2010 (KldB 2010)-Germany)">
                        <wd:ID wd:type="WID">16d569ce573c0159e47b20441e3b7149</wd:ID>
                        <wd:ID wd:type="Job_Classification_Reference_ID">KldB2010_Germany_1_Land-,_Forst-_und_Tierwirtschaft_und_Gartenbau</wd:ID>
                     </wd:Job_Classification_Reference>
                     <wd:Job_Classification_Data>
                        <wd:ID>KldB2010_Germany_1_Land-,_Forst-_und_Tierwirtschaft_und_Gartenbau</wd:ID>
                        <wd:Job_Classification_ID>1</wd:Job_Classification_ID>
                        <wd:Description>Land-, Forst- und Tierwirtschaft und Gartenbau</wd:Description>
                        <wd:Inactive>0</wd:Inactive>
                     </wd:Job_Classification_Data>
                  </wd:Job_Classification>
                  <wd:Job_Classification>
                     <wd:Job_Classification_Reference wd:Descriptor="11 - Land-, Tier- und Forstwirtschaftsberufe (Klassifikation der Berufe 2010 (KldB 2010)-Germany)">
                        <wd:ID wd:type="WID">16d569ce573c016e488520441e3b7249</wd:ID>
                        <wd:ID wd:type="Job_Classification_Reference_ID">KldB2010_Germany_11_Land-,_Tier-_und_Forstwirtschaftsberufe</wd:ID>
                     </wd:Job_Classification_Reference>
                     <wd:Job_Classification_Data>
                        <wd:ID>KldB2010_Germany_11_Land-,_Tier-_und_Forstwirtschaftsberufe</wd:ID>
                        <wd:Job_Classification_ID>11</wd:Job_Classification_ID>
                        <wd:Description>Land-, Tier- und Forstwirtschaftsberufe</wd:Description>
                        <wd:Inactive>0</wd:Inactive>
                     </wd:Job_Classification_Data>
                  </wd:Job_Classification>
               </wd:Job_Classification_Group_Data>
            </wd:Job_Classification_Group>
         </wd:Response_Data>
      </wd:Get_Job_Classification_Groups_Response>
   </env:Body>
</env:Envelope>

У меня есть простой XSLT, чтобы создать его безJob_Classification_Reference_ID

<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform" xmlns:wd="urn:com.workday/bsvc" xmlns:env="http://schemas.xmlsoap.org/soap/envelope/">
    <xsl:output method="text" version="1.0" encoding="UTF-8" indent="yes"/>
    <xsl:variable name="newline">
        <xsl:text>&#166;</xsl:text>
    </xsl:variable>
    <xsl:variable name="comma">
        <xsl:text>&#44;</xsl:text>
    </xsl:variable>
    <xsl:variable name="quote">
        <xsl:text>&#39;</xsl:text>
    </xsl:variable>
    <xsl:variable name="rs">
        <xsl:text>&#124;</xsl:text>
    </xsl:variable>
    <xsl:template match="/">
        <xsl:apply-templates select="/env:Envelope/env:Body/wd:Get_Job_Classification_Groups_Response/wd:Response_Data"/>
    </xsl:template>
    <xsl:template match="/env:Envelope/env:Body/wd:Get_Job_Classification_Groups_Response/wd:Response_Data">
        <xsl:for-each select="wd:Job_Classification_Group/wd:Job_Classification_Group_Data/wd:Job_Classification/wd:Job_Classification_Reference/wd:ID[2]">
            <xsl:value-of select="../../../wd:ID"/>
            <xsl:value-of select="$rs"/>
            <xsl:value-of select="../../../wd:Effective_Date"/>
            <xsl:value-of select="$rs"/>
            <xsl:value-of select="../../../wd:Job_Classification_Group_Name"/>
            <xsl:value-of select="$rs"/>
            <xsl:value-of select="../../../wd:Inactive"/>
            <xsl:value-of select="$rs"/>
            <xsl:value-of select="../../../wd:Location_Reference/wd:ID[2]"/>
            <xsl:value-of select="$rs"/>
            <xsl:value-of select="../../../wd:Location_Reference/wd:ID[3]"/>
            <xsl:value-of select="$rs"/>
            <xsl:value-of select="../../../wd:Location_Reference/wd:ID[4]"/>
            <xsl:value-of select="$rs"/>
            <xsl:value-of select="."/>
            <xsl:if test="position() != last()">
                <xsl:value-of select="$newline"/>
            </xsl:if>
        </xsl:for-each>
    </xsl:template>
</xsl:stylesheet>

Какие выходы:

KldB2010_Germany|2018-04-18-07:00|Klassifikation der Berufe 2010 (KldB 2010)|0|DE|DEU|276|KldB2010_Germany_1_Land-,_Forst-_und_Tierwirtschaft_und_Gartenbau¦KldB2010_Germany|2018-04-18-07:00|Klassifikation der Berufe 2010 (KldB 2010)|0|DE|DEU|276|KldB2010_Germany_11_Land-,_Tier-_und_Forstwirtschaftsberufe

Что близко, но не имеет Job_Classification_Group_ID

Я не могу понять, как сохранитьповторяя Job_Classification_Reference_ID и добавляя Job_Classification_Group_ID.Я попытался создать другой шаблон, который был вызван из цикла, но получил ошибку (используя XMLSpy).Этот шаблон просто выведет значение Job_Classification_Reference_ID.

РЕДАКТИРОВАТЬ: Ожидаемый результат

KldB2010_Germany|KldB2010_Germany|2018-04-18-07:00|Klassifikation der Berufe 2010 (KldB 2010)|0|DE|DEU|276|KldB2010_Germany_1_Land-,_Forst-_und_Tierwirtschaft_und_Gartenbau¦
KldB2010_Germany|KldB2010_Germany|2018-04-18-07:00|Klassifikation der Berufe 2010 (KldB 2010)|0|DE|DEU|276|KldB2010_Germany_11_Land-,_Tier-_und_Forstwirtschaftsberufe

Но первый столбец Job_Classification_Group_ID из wd:Job_Classification_Group_Reference.Не wd:Job_Classification_Group_Data.Это второй столбец

1 Ответ

0 голосов
/ 21 мая 2018

Есть несколько предложений для достижения желаемого результата.Требуется получить значение

<xsl:value-of select="wd:Job_Classification_Reference/wd:ID[@wd:type='Job_Classification_Reference_ID']"/>

в отдельных строках выходного текста.Для этого <xsl:for-each> должен работать на <wd:Job_Classification> вместо wd:Job_Classification/wd:Job_Classification_Reference/wd:ID[2].

Во-вторых, в этом конкретном сценарии вместо использования ../../../ для повышения уровней доступа к значениям родительского узла,лучше использовать ось ancestor::, которая поможет легко создать XPath и перейти к нужному узлу.Это также помогает понять, к какому значению элемента обращаются, просто взглянув на код XSLT.

В-третьих, вместо доступа к значениям с помощью wd:ID[2], wd:ID[3], wd:ID[4] было бы хорошо получить к ним доступиспользуя значение атрибута @wd:type, т.е. wd:ID[@wd:type='ISO_3166-1_Alpha-2_Code'] и т. д. для остальных.Это гарантирует, что выход не изменится, даже если последовательность элементов wd:ID во входе изменится.

На основании приведенных выше предложений шаблон wd:ResponseData будет изменен, как показано ниже.

<xsl:template match="/env:Envelope/env:Body/wd:Get_Job_Classification_Groups_Response/wd:Response_Data">
    <xsl:for-each select="wd:Job_Classification_Group/wd:Job_Classification_Group_Data/wd:Job_Classification">
        <xsl:value-of select="ancestor::wd:Job_Classification_Group/wd:Job_Classification_Group_Reference/wd:ID[@wd:type='Job_Classification_Group_ID']" />
        <xsl:value-of select="$rs"/>
        <xsl:value-of select="ancestor::wd:Job_Classification_Group/wd:Job_Classification_Group_Data/wd:ID" />
        <xsl:value-of select="$rs"/>
        <xsl:value-of select="ancestor::wd:Job_Classification_Group/wd:Job_Classification_Group_Data/wd:Effective_Date"/>
        <xsl:value-of select="$rs"/>
        <xsl:value-of select="ancestor::wd:Job_Classification_Group/wd:Job_Classification_Group_Data/wd:Job_Classification_Group_Name"/>
        <xsl:value-of select="$rs"/>
        <xsl:value-of select="ancestor::wd:Job_Classification_Group/wd:Job_Classification_Group_Data/wd:Inactive"/>
        <xsl:value-of select="$rs"/>
        <xsl:value-of select="ancestor::wd:Job_Classification_Group/wd:Job_Classification_Group_Data/wd:Location_Reference/wd:ID[@wd:type='ISO_3166-1_Alpha-2_Code']"/>
        <xsl:value-of select="$rs"/>
        <xsl:value-of select="ancestor::wd:Job_Classification_Group/wd:Job_Classification_Group_Data/wd:Location_Reference/wd:ID[@wd:type='ISO_3166-1_Alpha-3_Code']"/>
        <xsl:value-of select="$rs"/>
        <xsl:value-of select="ancestor::wd:Job_Classification_Group/wd:Job_Classification_Group_Data/wd:Location_Reference/wd:ID[@wd:type='ISO_3166-1_Numeric-3_Code']"/>
        <xsl:value-of select="$rs"/>
        <xsl:value-of select="wd:Job_Classification_Reference/wd:ID[@wd:type='Job_Classification_Reference_ID']"/>
        <xsl:if test="position() != last()">
            <xsl:value-of select="$newline"/>
            <xsl:text>&#xA;</xsl:text>
        </xsl:if> 
    </xsl:for-each>
</xsl:template>

Будет сгенерирован необходимый вывод

KldB2010_Germany|KldB2010_Germany|2018-04-18-07:00|Klassifikation der Berufe 2010 (KldB 2010)|0|DE|DEU|276|KldB2010_Germany_1_Land-,_Forst-_und_Tierwirtschaft_und_Gartenbau¦
KldB2010_Germany|KldB2010_Germany|2018-04-18-07:00|Klassifikation der Berufe 2010 (KldB 2010)|0|DE|DEU|276|KldB2010_Germany_11_Land-,_Tier-_und_Forstwirtschaftsberufe
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...