Если вам действительно нужно, вы можете сделать это с помощью компиляции во время выполнения:
import scala.reflect.runtime.universe
import scala.tools.reflect.ToolBox
def compileCaseClass(name: String, values: (String, String)*): Class[_] = {
val tb = universe.runtimeMirror(getClass.getClassLoader).mkToolBox()
val code = s"""
|case class $name(${values.map{case (n, t) => n + ": " + t}.mkString(",")})
|scala.reflect.classTag[$name].runtimeClass
""".stripMargin
println(code)
tb.compile(tb.parse(code))().asInstanceOf[Class[_]]
}
Пример использования:
val arr = Array("emp_id", "emp_name", "city")
val types = Array.fill(3){"String"}
val emp = compileCaseClass("Emp", (arr zip types): _*)
val inst = emp.getConstructors.head.newInstance("foo", "bar", "baz")
println(inst)
это действительно выводит обычный toString
экземпляра класса case:
Emp(foo,bar,baz)
Обратите внимание, что для него требуется набор инструментов отражения / компилятора в качестве зависимости: он есть, если вы запускаете его в REPL или в виде скрипта, но в обычных проектах,Вы должны добавить его как отдельную зависимость.