我有一个由项目节点组成的元素结构,我用Nokogiri这样解析:
@xml.css('item').each do |item|
# do something
end
现在这个项目有一个看起来像这样的部分(每个项目都有这个元素,id如下):
<customfield id="customfield_10004" key="com.atlassian.jira.plugin.system.customfieldtypes:float">
<customfieldname>Yada yada</customfieldname>
<customfieldvalues>
<customfieldvalue>8.0</customfieldvalue>
</customfieldvalues>
</customfield>
我想从中解析8.0值。在另一个SO答案中,我发现你可以使用这样的东西(用于HTML):
item.xpath("//customfield[@id='customfield_10004']").css('customfieldvalue')
不幸的是,这似乎以相同的顺序返回了一个所有值的字符串,而不是我正在查看的项目节点的特定值
有人知道如何解析customfieldwalue节点中的浮点值吗?
您的问题是在xpath查询开始时使用//
,它告诉xpath引擎从文档的根开始并查找所有匹配的内容,而不管您的当前节点是什么。请尝试使用./
。
尝试使用XPath表达式来识别元素并提取第一个匹配节点的文本:
@xml.xpath('//item').each do |item|
path = "//customfield[@id='customfield_10004']/*/customfieldvalue"
item.xpath(path).first.text.to_f // => 8.0, etc
end