私はこのxmlファイルを持っています:
<pas>
<rulepar>
<name1>Hi</name1>
<name2></name2>
<type>DOUBLE</type>
<oper>HIGH</oper>
<val1>103619.9</val1>
<bId>2</bId>
</rulepar>
<rulepar>
<name1>Hi</name1>
<name2></name2>
<type>Text</type>
<oper>LOW</oper>
<sumval1>-103.67</sumval1>
<bId>3</bId>
</rulepar>
</pas><rulepar>
<name1>Hi</name1>
<name2></name2>
<type>Text</type>
<oper>LOW</oper>
<val1>10</val1>
<bId>3</bId>
</rulepar>
</pas>
この xsl ファイルで:
<?xml version="1.0" encoding="UTF-8"?>
<xsl:stylesheet xmlns:xsl="http://www.w3.org/1999/XSL/Transform" version="1.0"
xmlns:ex="http://exslt.org/dates-and-times" extension-element-prefixes="ex">
<xsl:output method="xml" version="1.0" encoding="UTF-8" indent="no" xml:space="preserve"/>
<xsl:template match="node()|@*">
<xsl:copy>
<xsl:apply-templates select="node()|@*"/>
</xsl:copy>
</xsl:template>
<xsl:template match="val1|sumval1">
<val111><xsl:value-of select="."/></val111>
</xsl:template>
変換を行うと、結果として次のようになります。
<pas>
<rulepar>
<name1>Hi</name1>
<name2></name2>
<type>DOUBLE</type>
<oper>HIGH</oper>
<val111>103619.9</val111>
<bId>2</bId>
</rulepar>
<rulepar>
<name1>Hi</name1>
<name2></name2>
<type>Text</type>
<oper>LOW</oper>
<val111>-103.67</val111>
<bId>3</bId>
</rulepar>
</pas><rulepar>
<name1>Hi</name1>
<name2></name2>
<type>Text</type>
<oper>LOW</oper>
<val111>10</val111>
<bId>3</bId>
</rulepar>
</pas>
私は通常、この出力を期待していました:
<pas>
<rulepar>
<name1>Hi</name1>
<name2></name2>
<type>DOUBLE</type>
<oper>HIGH</oper>
<val111>103619</val111>
<bId>2</bId>
</rulepar>
<rulepar>
<name1>Hi</name1>
<name2></name2>
<type>Text</type>
<oper>LOW</oper>
<val111>-103</val111>
<bId>3</bId>
</rulepar>
</pas><rulepar>
<name1>Hi</name1>
<name2></name2>
<type>Text</type>
<oper>LOW</oper>
<val111>10</val111>
<bId>3</bId>
</rulepar>
</pas>
では、予想される出力ファイルに示されているように、結果で数値 103619.9 の整数部分のみを取得するにはどうすればよいでしょうか? 数値が 10 進数のみで、この数値が <0 の場合でも、歩けるソリューションが必要です。ご協力いただきありがとうございます。