Как обрабатывать вложенные элементы и просто выводить один в xslt - PullRequest
0 голосов
/ 29 июня 2018

Это первый раз для меня, чтобы обрабатывать XML с вложенными элементами и искать советы. Мне нужно преобразовать входной XML для вывода только одного элемента в выходной XML.

Вот мой входной XML, чтобы выглядеть так. У меня есть два элемента для <ImageId> и два элемента для <ReferenceNumber>. Мне нужно только вывести один <ImageId> и один <ReferenceNumber>, которые являются первыми двумя элементами под тегом <InquireCase>.

Если я сделаю <xsl:copy-of select, он скопирует все поля ReferenceNumber. У меня есть дубликаты результатов <ReferenceNumber>201801364201801364</ReferenceNumber>. Если я это сделаю, в элементе <ImageId></ImageId> нет значения. Я сделал <xsl:apply-templates select="ImageId></xsl:apply-templates>, но вывод XML показывает пустым.

Любая помощь очень ценится.

<?xml version='1.0'?>
<InquiryRequest>
    <InquiryCase>
        <ImageId>123453453</ImageId>
        <ReferenceNumber>UDHD654634</ReferenceNumber>
    </InquiryCase>
    <Document>
        <Lastname>MOUSE</Lastname>
    </Document>
    <InquiryCase>
        <ImageId>123453453</ImageId>
        <ReferenceNumber>UDHD654634</ReferenceNumber>
    </InquiryCase>
</InquiryRequest>

Вот мой 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" 
    xmlns:env ="urn:envision">
  <xsl:output method="xml" indent="yes"/>
  <msxsl:text disable-output-escaping="yes"></msxsl:text>

    <xsl:template match="InquiryRequest">            
        <xsl:element name ="ImageId">
            <xsl:value-of select="ImageId"/>
        </xsl:element>                                            
        <xsl:element name="InquiryCase">   
            <xsl:element name ="ReferenceNumber">
                <xsl:copy-of select="//InquiryCase/ReferenceNumber/text()"/>
            </xsl:element>                          
        </xsl:element>   <!-- added by edit -->
    </xsl:template>

    <xsl:template match="ImageId">
        <xsl:element name ="ImageId">
            <xsl:apply-templates select="ImageId"></xsl:apply-templates>
        </xsl:element>
    </xsl:template>

</xsl:stylesheet>

Ответы [ 3 ]

0 голосов
/ 30 июня 2018
<xsl:output method="xml" indent="yes"/>
    <xsl:template match="InquiryRequest">
        <xsl:copy>
            <xsl:apply-templates select="InquiryCase"/>
        </xsl:copy>
    </xsl:template>
    <xsl:template match="InquiryCase">
        <xsl:copy>
            <ImageId>
                <xsl:value-of select="ImageId"/>
            </ImageId>
            <ReferenceNumber>
                <xsl:value-of select="ReferenceNumber"/>
            </ReferenceNumber>
        </xsl:copy>
    </xsl:template>
    <xsl:template match="InquiryCase[following-sibling::InquiryCase/ImageId =  current()/ImageId]"/>
You may also do like this.
0 голосов
/ 12 июля 2018
 Here's the final layout that resolves my issue

         <xsl:variable name="ImageId" select="descendant::ImageId"/>
          <xsl:variable name="connStr" select="concat(env:GetScriptingLookup('@Database'), 'Trusted_Connection=YES')" />
          <xsl:variable name="provider">System.Data.SqlClient</xsl:variable>

          <xsl:variable name="DateTime">
           <xsl:variable name="sqlXref"> 
   SELECT CONVERT(VARCHAR(10), GETDATE(), 101) + ' ' + CONVERT(VARCHAR(13), GETDATE(), 108) AS 'CURRENT_DTTM' FROM IMAGES_DETAIL (nolock) WHERE IMAGE_ID = &apos;<xsl:value-of select="$ImageId"/>&apos;
            </xsl:variable>
            <xsl:value-of select="env:ExecuteScalar($provider, $connStr, $sqlXref)"/>
              </xsl:variable>
                <xsl:template match="InquiryRequest">     `enter code here`       
                   <xsl:element name ="ImageId">
                      <xsl:value-of select="ImageId"/>
                   </xsl:element>

                  <xsl:element name="RequestDateTime">
                  <xsl:value-of select="$DateTime"/>
              </xsl:element>

                   <xsl:element name="InquiryCase">   
                      <xsl:element name ="ReferenceNumber">
                          <xsl:value-of select="InquiryCase[1]/ReferenceNumber"/>
                    </xsl:element>                       
            </xsl:element>  
          </xsl:template>   
      </xsl:stylesheet>
0 голосов
/ 30 июня 2018

Одним из возможных решений является следующий шаблон. [1] обозначает первый элемент InquiryCase:

<xsl:template match="InquiryRequest">            
    <xsl:element name="InquiryCase">   
        <xsl:element name ="ImageId">
            <xsl:value-of select="InquiryCase[1]/ImageId"/>
        </xsl:element>                                            
        <xsl:element name ="ReferenceNumber">
            <xsl:copy-of select="InquiryCase[1]/ReferenceNumber/text()"/>
        </xsl:element>                          
    </xsl:element>   <!-- added by edit -->
</xsl:template>

Вывод:

<?xml version="1.0" encoding="UTF-8"?>
<InquiryCase>
   <ImageId>123453453</ImageId>
   <ReferenceNumber>UDHD654634</ReferenceNumber>
</InquiryCase>
...