加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

从Scala中的字符串读取案例类对象(像Haskell的“读”类型类)

发布时间:2020-12-16 09:16:06 所属栏目:安全 来源:网络整理
导读:我想读一个字符串作为一个case类的一个实例.例如,如果函数被命名为“read”,它将让我执行以下操作: case class Person(name: String,age: Int) val personString: String = "Person(Bob,42)" val person: Person = read(personString) 这与Haskell中的读取
我想读一个字符串作为一个case类的一个实例.例如,如果函数被命名为“read”,它将让我执行以下操作:

> case class Person(name: String,age: Int)
> val personString: String = "Person(Bob,42)"
> val person: Person = read(personString)

这与Haskell中的读取类型类似.

解决方法

dflemstr更多地回答了设置实际的读取方法 – 我会回答更多的实际解析方法.

我的方法有两个对象可以在scala的模式匹配块中使用. AsInt允许您匹配代表Ints的字符串,PersonString是Person反序列化的实际实现.

object AsInt {
  def unapply(s: String) = try{ Some(s.toInt) } catch {
    case e: NumberFormatException => None
  }
}

val PersonRegex = "Person((.*),(d+))".r

object PersonString {
  def unapply(str: String): Option[Person] = str match {
    case PersonRegex(name,AsInt(age)) => Some(Person(name,age))
    case _ => None
  }
}

魔法是在无法使用的方法,哪个scala有语法糖.所以使用PersonString对象,你可以做

val person = PersonString.unapply("Person(Bob,42)")
//  person will be Some(Person("Bob",42))

或者您可以使用模式匹配块来与该人做某事:

"Person(Bob,42)" match {
  case PersonString(person) => println(person.name + " " + person.age)
  case _ => println("Didn't get a person")
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读