2

我有一个代表我需要解析并保存在数据库中的模型的 XML 文档。在某些字段中,它可能具有由 xsi:nil 指示的 NULL 值。像这样

<quantity xsi:nil="true"/>

对于解析,我使用 scala.xml DSL。问题是我找不到任何方法来确定某事是否为零。这: (elem \ "quantity") 只是返回一个空字符串,然后当我尝试将其转换为数字时它会爆炸。用 Option 包装也无济于事。

有没有办法从那个 XML 片段中获取 None、Nil 甚至 null?

4

2 回答 2

3

在这种情况下,您可以将命名空间 URI 与 XML withattribute方法一起使用,以获取“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
于 2012-12-17T02:02:37.807 回答
3

如果您使用xtract,您可以结合使用 filter 和 otpional:

(__ \ "quantity").read[Node]
  .filter(_.attribute("http://www.w3.org/2001/XMLSchema-instance", "nil").isEmpty)
  .map(_.toDouble).optional

请参阅https://www.lucidchart.com/techblog/2016/07/12/introducing-xtract-a-new-xml-deserialization-library-for-scala/

免责声明:我在 Lucid Software 工作,并且是 xtract 的贡献者。

于 2016-07-12T18:05:32.867 回答