Передать содержимое узла XML для дополнительной обработки в XSLT

Передать содержимое узла XML для дополнительной обработки в XSLT

У меня есть длинный, сгенерированный человеком XML-файл с достаточной регулярностью, чтобы я мог идентифицировать его содержимое с помощью Xpath. Я пытаюсь переформатировать его в HTML-таблицу.

Исходный материал технически отформатирован как таблица только для визуального эффекта (не заставляйте меня начинать). Проблема в том, что описательная часть каждой записи может содержать произвольную разметку, которую мне нужно передать для дополнительной обработки. Я не понял, как получить содержимое описания и обработать его соответствующим образом.

Я не получаю желаемых результатов, используя value-of или copy-of. Я, вероятно, упускаю что-то очевидное.

Образец документа:

<?xml version="1.0" encoding="UTF-8"?>
<manual>
    <body>
        <chapter>
            <table>
                <thead>
                    <row>
                        <entry>
                            <para>Some parameter name</para>
                        </entry>
                        <entry>
                            <para>1</para>
                        </entry>
                    </row>
                </thead>
                <tbody>
                    <row>
                        <entry>
                            <para>Range</para>
                        </entry>
                        <entry>
                            <para>1–10</para>
                        </entry>
                    </row>
                    <row>
                        <entry>
                            <para>Description</para>
                        </entry>
                        <entry>
                            <para>Sets the type of process module.</para>
                            <para>There can be <emphasis>more arbitrary markup</emphasis> in here.</para>
                            <list>
                                <item>Even a list</item>
                            </list>
                        </entry>
                    </row>
                </tbody>
            </table>
            <!-- and so on -->
        </chapter>
    </body>
</manual>

Я пробовал разные варианты следующего фрагмента XSLT

        <xsl:for-each select="table"> 
        <tr>
            <!-- insert additional code here -->
            <td class="desc"> <xsl:value-of select="//tbody/row[2]/entry[2]/*"><xsl:apply-templates select="@*|node()" /></xsl:value-of> </td>
        </tr>
        </xsl:for-each> 

решение1

Я переусердствовал. Или, может быть, недоусердствовал.

<td class="desc">
   <xsl:apply-templates select="tgroup/tbody/row[2]/entry[2]/*" />
</td>

Связанный контент