[英]Transform xml fields to key/value pairs in PI XSLT mapping
在 SAP PI 中,我有來自其余服務(Web 配置器)的 xml 文件,這些文件的字段可能因產品而異。 例如,產品 A 具有顏色、高度和寬度,而產品 B 具有顏色、高度、寬度和深度。
示例傳入 XML:
<?xml version="1.0" encoding="UTF-8"?>
<Order>
<Products>
<Product>
<Color>Black</Color>
<Height>2000</Height>
<Width>1000</Width>
</Product>
</Products>
</Order>
為了處理這個“通用”,我想通過 1.0 XSL 轉換將字段轉換為某種鍵/值對結構。
示例所需的 XML:
<?xml version="1.0" encoding="UTF-8"?>
<Order>
<Products>
<Product>
<Var>
<VarName>Color</VarName>
<VarValue>Black</VarValue>
</Var>
<Var>
<VarName>Height</VarName>
<VarValue>2000</VarValue>
</Var>
<Var>
<VarName>Width</VarName>
<VarValue>1000</VarValue>
</Var>
</Product>
</Products>
</Order>
我找到了一篇文章,它以另一種方式描述了XSLT:Convert Name/Value pair and transform an XML
這是馬丁告訴你的:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet version="2.0" xmlns:xsl="http://www.w3.org/1999/XSL/Transform">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="yes"/>
<xsl:template match="Product/*">
<Var>
<VarName>
<xsl:value-of select="name()"/>
</VarName>
<VarValue>
<xsl:value-of select="."/>
</VarValue>
</Var>
</xsl:template>
<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>
</xsl:stylesheet>
<xsl:template match="@*|node()">
<xsl:copy>
<xsl:apply-templates select="@*|node()"/>
</xsl:copy>
</xsl:template>
<xsl:template match="Products">
<xsl:copy>
<xsl:for-each select="Product">
<Product>
<xsl:for-each select="./*">
<Var>
<VarName><xsl:value-of select="local-name()"/></VarName>
<VarValue><xsl:value-of select="."/></VarValue>
</Var>
</xsl:for-each>
</Product>
</xsl:for-each>
</xsl:copy>
</xsl:template>
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.