我在Play框架驱动的webapp中有简单的实体。它看起来像这样:
case class MyItem(id: Option[Long] = None, name: String, comments: List[Comment])
case class Comment(commentDate: Date, commentText: String)
我从数据库中获取XML,如下所示:
<?xml version="1.0"?>
<item>
<id>1</id>
<name>real item</name>
<comments>
<comment>
<comment_date>01.01.1970</comment_date>
<comment_text>it rocks</comment_text>
</comment>
<comment>
<comment_date>02.01.1970</comment_date>
<comment_text>it's terrible</comment_text>
</comment>
</comments>
</item>
现在我不知道将它解析为模型和表单映射。
我的表单映射以防万一(现在不编译):
val itemForm = Form(
mapping(
"id" -> optional(longNumber),
"name" -> nonEmptyText,
"comments" -> list(mapping(
"commentDate" -> date("dd.mm.yyyy"),
"commentText" -> text
)(Comment.apply)(Comment.unapply))
)(MyItem.apply)(MyItem.unapply)
)
答案 0 :(得分:4)
以下是问题第一部分的示例代码:
import scala.xml.{Comment => _, _}
case class Comment(commentDate: String, commentText: String)
case class MyItem(id: Option[Long] = None, name: String, comments: List[Comment])
object MyParser {
def parse(el: Elem) =
MyItem(Some((el \ "id").text.toLong), (el \ "name").text,
(el \\ "comment") map { c => Comment((c \ "comment_date").text, (c \ "comment_text").text)} toList)
}
REPL的结果:
scala> MyParser.parse(xml)
MyParser.parse(xml)
res1: MyItem = MyItem(Some(1),real item,List(Comment(01.01.1970,it rocks), Comment(02.01.1970,it's terrible)))
我可以自由地将commentDate
更改为String
,因为我希望程序看起来更简单。解析Date
非常简单,只需阅读Joda Time library documentation.
答案 1 :(得分:0)
表单映射不进行XML解析,只进行表单解析,您必须使用Scala XML支持(或您喜欢的某些库)。搜索互联网,你会发现许多如何使用它的例子。