我有一个表示我的模型的XML文档,我需要在db中解析并保存。在某些字段中,它可能具有由xsi:nil指示的NULL值。像这样
<quantity xsi:nil="true"/>
对于解析,我使用scala.xml DSL。问题是我找不到任何方法来确定某些东西是否为零。这个:(elem \“quantity”)只返回一个空字符串,然后当我尝试将其转换为数字时会爆炸。用Option包装它也无济于事。
有没有办法从XML文件中获取None,Nil甚至null?
答案 0 :(得分:3)
在这种情况下,您可以使用带有attribute
方法的XML的命名空间URI来获取“xsi:nil”属性中的文本。
这是一个有效的例子:
scala> val xml = <quantity xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:nil="true"/>
xml: scala.xml.Elem = <quantity xsi:nil="true" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"></quantity>
scala> xml.attribute("http://www.w3.org/2001/XMLSchema-instance", "nil")
res0: Option[Seq[scala.xml.Node]] = Some(true)
如果您认为空节点为None,那么您甚至不需要打扰该属性。只需过滤掉其中没有任何文字的节点,然后使用headOption
获取值。
scala> val s1 = <quantity xsi:nil="true">12</quantity>
s1: scala.xml.Elem = <quantity xsi:nil="true">12</quantity>
scala> val s2 = <quantity xsi:nil="true"/>
s2: scala.xml.Elem = <quantity xsi:nil="true"></quantity>
scala> s1.filterNot(_.text.isEmpty).headOption.map(_.text.toInt)
res10: Option[Int] = Some(12)
scala> s2.filterNot(_.text.isEmpty).headOption.map(_.text.toInt)
res11: Option[Int] = None
答案 1 :(得分:3)
如果您使用xtract,可以使用过滤器和otpional的组合来执行此操作:
(__ \ "quantity").read[Node]
.filter(_.attribute("http://www.w3.org/2001/XMLSchema-instance", "nil").isEmpty)
.map(_.toDouble).optional
免责声明:我为Lucid Software工作,并且是xtract的贡献者。