9
我想选择名为“a”的节点的第一个子元素。我现在所得到的是:选择scala中节点的所有子元素
(xml \ "a")(0).child.collect {case e: Elem => e}
这是相当冗长。我正在寻找类似的东西:
xml \ "a" \ "*"
这是可能的斯卡拉?
我想选择名为“a”的节点的第一个子元素。我现在所得到的是:选择scala中节点的所有子元素
(xml \ "a")(0).child.collect {case e: Elem => e}
这是相当冗长。我正在寻找类似的东西:
xml \ "a" \ "*"
这是可能的斯卡拉?
您无法对NodeSeq
上的现有\
或\\
方法进行任何操作。 但是你可以用新\*
方法(注意缺乏或空格字符)延长NodeSeq,按照皮条客,你的库模式:
import xml.{NodeSeq, Elem}
class ChildSelectable(ns: NodeSeq) {
def \* = ns flatMap { _ match {
case e:Elem => e.child
case _ => NodeSeq.Empty
} }
}
implicit def nodeSeqIsChildSelectable(xml: NodeSeq) = new ChildSelectable(xml)
在REPL,这则给了我:
scala> val xml = <a><b><c>xxx</c></b></a>
xml: scala.xml.Elem = <a><b><c>xxx</c></b></a>
scala> xml \*
res7: scala.xml.NodeSeq = NodeSeq(<b><c>xxx</c></b>)
scala> xml \ "b" \*
res8: scala.xml.NodeSeq = NodeSeq(<c>xxx</c>)
scala> xml \ "b" \ "c" \*
res9: scala.xml.NodeSeq = NodeSeq(xxx)
这是非常接近你正在寻找:
import scala.xml.Elem
val xml = <a><b><c>HI</c></b></a>
println(xml)
println(xml \ "_")
println(xml \ "b")
println(xml \ "b" \ "_")
println(xml \ "b" \ "c")
println(xml \ "b" \ "c" \ "_")
<a><b><c>HI</c></b></a>
<b><c>HI</c></b>
<b><c>HI</c></b>
<c>HI</c>
<c>HI</c>
// Empty
钍比接受的答案好。 ``_“`完全符合要求,而不需要编写新的方法。更少的代码来维护,更少的非标准语法混淆下一个看你的代码的人。 – rumtscho 2014-11-25 06:13:20