我正在使用 Altova XMLSpy,但在tokenize()
使用 Xpath 2.0 的 Xpath 函数时遇到问题。
我有一个包含此标记的 XML,其中包含我需要的值:
<REF TyCd="INVREF2">VVQFAR CIG ZA5180AAB6</REF>
这是我用来检索我需要的值的 Xpath:
if (index-of(tokenize(/InvoiceMsg/INVOICE/REFS/REF[@TyCd='INVREF2'], ' '), 'CIG') > 0)
then
tokenize(/InvoiceMsg/INVOICE/REFS/REF[@TyCd='INVREF2'], ' ')[index-of(tokenize(/InvoiceMsg/INVOICE/REFS/REF[@TyCd='INVREF2'], ' '), 'CIG') + 1]
else
''
错误出现在tokenize()
函数的第三次使用中,并说:
意外的“原子”项 xs:字符串详细信息 XPTY0020:轴步骤中的上下文项必须是节点
此外,如果我使用固定字符串,像这样
tokenize(/InvoiceMsg/INVOICE/REFS/REF[@TyCd='INVREF2'], ' ')[index-of(tokenize('VVQFAR CIG ZA5180AAB6', ' '), 'CIG') + 1]
错误不会发生。
问题是:为什么错误只发生在那里(而不是在 if 语句中,例如),我能做什么?