Я пытаюсь преобразовать XML из следующих действий:Проблемы относительно трансформации XSLT
<entities xmlns="http://ws.wso2.org/dataservice"><entityIds>
137651b03d18c0efee947f8bda341fb1
</entityIds>
<entityIds>
aa88ce76d454a0135c89bfbd4def62cd
</entityIds>
</entities>
с использованием XSL следующего
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="1.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform"
xmlns:p="http://ws.wso2.org/dataservice">
<xsl:output method="xml" encoding="utf-8" indent="yes"/>
<xsl:template match="/">
<urlDetails>
<customerId>
<xsl:value-of select="//p:entityList/p:entity[1]/p:customerId" />
</customerId>
<entityIds>
<xsl:apply-templates/>
<xsl:for-each select="//p:entityList/p:entity">
<xsl:value-of select="p:entityId" />,
</xsl:for-each>
</entityIds>
</urlDetails>
</xsl:template>
</xsl:stylesheet>
An Я получаю вывод как:
<?xml version="1.0" encoding="utf-8"?>
<urlDetails xmlns:p="http://ws.wso2.org/dataservice">
<customerId/>
<entityIds>
137651b03d18c0efee947f8bda341fb1
aa88ce76d454a0135c89bfbd4def62cd
</entityIds>
</urlDetails>
Как я могу сделать вывод в запятой отдельно:
<?xml version="1.0" encoding="utf-8"?>
<urlDetails xmlns:p="http://ws.wso2.org/dataservice">
<customerId/>
<entityIds>
137651b03d18c0efee947f8bda341fb1 ,
aa88ce76d454a0135c89bfbd4def62cd
</entityIds>
</urlDetails>
Я использовал строку concat и using version2.0. Я использую сепаратор значений, оба не работают. Есть ли какие-либо другие методы?
Ну, входной образец, который вы разместили как элементы с именем 'entities' и' entityIds', но ваши выражения XPath выглядят как '// p: entityList/p: entity' и' p: entityId'. Таким образом, ни один из имен элементов в выражении пути не совпадает с точными именами элементов в выбранном образце. –
По этой причине, я ниспровергаю вопрос. –