如何在scala中保存案例类列表

时间:2014-03-04 20:33:38

标签: java scala save

我有一个名为Rdv的案例类:

case class Rdv(
  id: Option[Int],
  nom: String,
  prénom: String,
  sexe: Int,
  telPortable: String,
  telBureau: String,
  telPrivé: String,
  siteRDV: String,
  typeRDV: String,
  libelléRDV: String,
  numRDV: String,
  étape: String,
  dateRDV: Long,
  heureRDVString: String,
  statut: String,
  orderId: String)

我想在磁盘上保存这些元素的列表,稍后重新加载它们。 我试过java类(ObjectOutputStream,fileOutputStream,objectInputStream,fileInputStream),但我在检索步骤中有一个错误:语句

val n2 = ois.readObject().asInstanceOf[List[Rdv]]

总是会出错(classNotFound:Rdv),尽管在导入位置给出了正确的路径。

您知道保存此类对象的解决方法吗? 请提供一小段代码!

感谢

奥利弗

ps:使用Marshall类时遇到同样的错误,例如在此代码中:

object Application extends Controller {

def index = Action {

//implicit val Rdv2Writes = Json.writes[rdv2]

def rdvTordv2(rdv: Rdv): rdv2 = new rdv2(
  rdv.nom,
  rdv.prénom,
  rdv.dateRDV,
  rdv.heureRDVString,
  rdv.telPortable,
  rdv.telBureau,
  rdv.telPrivé,
  rdv.siteRDV,
  rdv.typeRDV,
  rdv.libelléRDV,
  rdv.orderId,
  rdv.statut)




val n = variables.manager.liste_locale
val out = new FileOutputStream("out")
out.write(Marshal.dump(n))
out.close

val in = new FileInputStream("out")
val bytes = Stream.continually(in.read).takeWhile(-1 !=).map(_.toByte).toArray
val bar: List[Rdv] = Marshal.load[List[Rdv]](bytes)        <--------------

val n3 = bar.map(rdv =>
  rdvTordv2(rdv))
println("n3:" + n3.size)




Ok(views.html.Application.olivier2(n3))

}

},

在带箭头的行中。 似乎转换到List [Rdv]类型会遇到问题,但为什么呢?这是戏吗!相关问题?


好吧,游戏有问题: 我使用以下代码创建了一个新的scala项目:

object Test1 extends App {

//pour des fins de test
case class Person(name:String,age:Int)
val liste_locale=List(new Person("paul",18))

val n = liste_locale
val out = new FileOutputStream("out")
out.write(Marshal.dump(n))
out.close

val in = new FileInputStream("out")
val bytes = Stream.continually(in.read).takeWhile(-1 !=).map(_.toByte).toArray
val bar: List[Person] = Marshal.load[List[Person]](bytes)
println(s"bar:size=${bar.size}")
}

并且显示效果良好(“bar:size = 1”)。

然后,我在play项目中修改了我之前的代码,在控制器类中,例如:

object Application extends Controller {

def index = Action {

//pour des fins de test
case class Person(name:String,age:Int)
val liste_locale=List(new Person("paul",18))

val n = liste_locale
val out = new FileOutputStream("out")
out.write(Marshal.dump(n))
out.close

val in = new FileInputStream("out")
val bytes = Stream.continually(in.read).takeWhile(-1 !=).map(_.toByte).toArray
val bar: List[Person] = Marshal.load[List[Person]](bytes)
println(s"bar:size=${bar.size}")


Ok(views.html.Application.olivier2(Nil))

}

}

我有一个错误说:

play.api.Application$$anon$1: Execution exception[[ClassNotFoundException: controllers.Application$$anonfun$index$1$Person$3]]

有没有人有答案?

编辑:我认为错误可能来自sbt,所以我修改了build.scala,例如:

import sbt._
import Keys._
import play.Project._

object ApplicationBuild extends Build {

val appName = "sms_play_2"
val appVersion = "1.0-SNAPSHOT"

val appDependencies = Seq(
// Add your project dependencies here,
jdbc,
anorm,
"com.typesafe.slick" % "slick_2.10" % "2.0.0",
"com.github.nscala-time" %% "nscala-time" % "0.6.0",
"org.xerial" % "sqlite-jdbc" % "3.7.2",
"org.quartz-scheduler" % "quartz" % "2.2.1",
"com.esotericsoftware.kryo" % "kryo" % "2.22",
"io.argonaut" %% "argonaut" % "6.0.2")

val mySettings = Seq(
(javaOptions in run) ++= Seq("-Dconfig.file=conf/dev.conf"))

val playCommonSettings = Seq(

Keys.fork := true)

val main = play.Project(appName, appVersion, appDependencies).settings(

  Keys.fork in run := true,
resolvers += Resolver.sonatypeRepo("snapshots")).settings(mySettings: _*)
.settings(playCommonSettings: _*)

}

但没有成功,错误仍然存​​在(未找到类别人员)

你可以帮帮我吗?

1 个答案:

答案 0 :(得分:0)

Scala Pickling具有合理的动力,并且该方法具有许多优点(许多繁重工作在编译时完成)。有一个可插入的序列化机制,支持像json这样的格式。