XML в форматированный текст с использованием XSLT

У меня есть XML в следующем формате:

<Order>
  <Customer>
     <Name>kapil</name>
     <AddressLine1>ABC</AddressLine1>
     <PostCode>12345</postCode>
  </Customer>
  <Customer>
     <Name>Soniya</name>
     <AddressLine1>XYZPER</AddressLine1>
     <PostCode>54321</postCode>
  </Customer>
  <Customer>
     <Name>kapil</name>
     <AddressLine1>ABC</AddressLine1>
     <PostCode>12345</postCode>
  </Customer>
</Order>

И я хочу текстовый файл в определенном формате как

Soniya    XYZPER   54321
Kapil     ABC      12345

Я хочу сделать это через XSLT.


person Kapil    schedule 06.08.2009    source источник


Ответы (4)


Чтобы дополнить строку пробелами в XSLT 1.0, вы можете использовать именованный шаблон следующим образом:

<xsl:template name="ppad">
    <xsl:param name="str" />
    <xsl:param name="chr" select="' '" />
    <xsl:param name="len" select="0" />
    <xsl:choose>
        <xsl:when test="string-length($str) &lt; $len">
            <xsl:call-template name="ppad">
                <xsl:with-param name="str" select="concat($str, $chr)" />
                <xsl:with-param name="len" select="$len" />
                <xsl:with-param name="chr" select="$chr" />
            </xsl:call-template>
        </xsl:when>
        <xsl:otherwise>
            <xsl:value-of select="$str" />
        </xsl:otherwise>
    </xsl:choose>
</xsl:template>

А затем вызовите его со строкой и длиной в качестве параметров:

<xsl:call-template name="rpad">
    <xsl:with-param name="str" select="Name" />
    <xsl:with-param name="len" select="16" />
</xsl:call-template>
person Jörn Horstmann    schedule 06.08.2009
comment
Большое спасибо, Джорн... но не могли бы вы реализовать это на моем примере выше и опубликовать... буду очень признателен.... На самом деле я новичок в XSLT :) - person Kapil; 06.08.2009

вы можете использовать XSL-FO и процессор XSL-FO, которые могут помочь вам отформатировать ваш вывод (табличное расположение ваших результатов в вашем случае) и вывести его в различные форматы (обычный текст, PDF ...). Для начала вы следует проверить w3schools и использовать Apache FOP — решение с открытым исходным кодом — для обработки вашего XML документы. Что касается меня, я использовал XSL-FO для создания PDF-файлов из XML-файлов.

person peroumal1    schedule 06.08.2009
comment
Я не могу использовать XSL-FO, потому что в моем требовании указано, что мне нужно использовать только XSLT. - person Kapil; 06.08.2009

<?xml version='1.0' encoding='UTF-8'?>
<xsl:stylesheet 
  xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
  version="1.0"
>

<xsl:template match='/Order'>
  <xsl:for-each select='Customer'>
    <xsl:value-of select='Name' />
    <xsl:value-of select='AddressLine1' />
    <xsl:value-of select='PostCode' />
  </xsl:for-each>
</xsl:template>

</xsl:stylesheet>

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

person Ned Batchelder    schedule 06.08.2009
comment
Спасибо за вашу помощь, Нед, но... именно это я и хочу сделать... все столбцы должны быть правильно выстроены... т.е. текст должен быть отформатирован... каждый новый адрес и почтовый индекс должны начинаться с другого - person Kapil; 06.08.2009

Улучшен ответ Йорна Хорстманна, включивший lpad и rpad.

<xsl:template name="rpad">
    <xsl:param name="str"/>
    <xsl:param name="len" select="0" />
    <xsl:param name="chr" select="' '" />
    <xsl:call-template name="pad">
        <xsl:with-param name="str" select="$str" />
        <xsl:with-param name="len" select="$len" />
        <xsl:with-param name="chr" select="$chr" />
        </xsl:call-template>
</xsl:template>

<xsl:template name="lpad">
    <xsl:param name="str"/>
    <xsl:param name="len" select="0" />
    <xsl:param name="chr" select="' '" />
    <xsl:call-template name="pad">
        <xsl:with-param name="str" select="$str" />
        <xsl:with-param name="len" select="$len" />
        <xsl:with-param name="chr" select="$chr" />
        <xsl:with-param name="justify" select="'right'" />
    </xsl:call-template>
</xsl:template>

<xsl:template name="pad">
    <xsl:param name="str"/>
    <xsl:param name="len" select="0" />     
    <xsl:param name="chr" select="' '" />
    <xsl:param name="justify" select="'left'"/>
    <xsl:choose>
        <xsl:when test="string-length($str) &lt; $len">
            <xsl:variable name="newStr">
                <xsl:choose>
                    <xsl:when test="$justify = 'left'">
                        <xsl:value-of select="concat($str,' ')"/>
                    </xsl:when>
                    <xsl:otherwise>
                        <xsl:value-of select="concat(' ',$str)"/>
                    </xsl:otherwise>
                </xsl:choose>
            </xsl:variable>
            <xsl:call-template name="pad">
                <xsl:with-param name="len" select="$len"/>
                <xsl:with-param name="justify" select="$justify" />
                <xsl:with-param name="chr" select="$chr" />
                <xsl:with-param name="str" select="$newStr" />
            </xsl:call-template>
        </xsl:when>
        <xsl:otherwise>
            <xsl:value-of select="$str"/>
        </xsl:otherwise>            
    </xsl:choose>
</xsl:template>

Чтобы заполнить строку 'myvalue' пробелами до 20 символов, используйте:

<xsl:call-template name="rpad">
    <xsl:with-param name="str" select="'myvalue'" />
    <xsl:with-param name="len" select="20" />
</xsl:call-template>

Чтобы заполнить строку 'myvalue' пробелами до 36 символов, используйте:

<xsl:call-template name="lpad">
    <xsl:with-param name="str" select="'myvalue'" />
    <xsl:with-param name="len" select="36" />
</xsl:call-template>

или панель вызова, непосредственно указывающая желаемое выравнивание текста (т.е. слева или справа)

<xsl:call-template name="pad">
    <xsl:with-param name="str" select="'myvalue'" />
    <xsl:with-param name="len" select="36" />
    <xsl:with-param name="justify" select="'right'" />
</xsl:call-template>
person Pancho    schedule 27.06.2015