0
我是XSLT的初學者,並使用它通過Java將XML轉換爲XML。帶分組的XSLT 1.0計算
源XML:
<Response>
<Data>
<Book name="A" value="1"/>
<Book name="B" value="2"/>
<Book name="C" value="1"/>
</Data>
<Result>
<Prices>
<Price type="A" value="100"/>
<Price type="B" value="60"/>
<Price type="C" value="40"/>
</Prices>
</Result>
</Response>
XSLT:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0">
<xsl:output method="xml" indent="yes" />
<xsl:template match="/">
<xsl:element name="Books">
<xsl:variable name="BookType" select="//@type" />
<xsl:attribute name="Total">
<xsl:value-of select="sum(//Price[@type=$BookType]/@value)"/>
</xsl:attribute>
</xsl:element>
</xsl:template>
</xsl:stylesheet>
輸出XML:
<Books Total="200"/>
預期輸出XML:
<Books Total="260"/>
在源XML我收到沒有一本書和它的價格,但他們是不相關的。
<Price>
標記表示一本書的價格。 我需要計算的所有書籍的總價格如下
Price of one book x no of books
For A : 100 x 1 = 100
For B : 60 x 2 = 120
For C : 40 x 1 = 040
------------------------
Total Price is = 260
請幫助。