我有这个 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 的整数部分,如预期的输出文件中所示?我想要一个解决方案,当数字只是一个十进制数字并且这个数字<0时也可以走。谢谢你的帮助。