如何打印收集序列的内容

时间:2019-06-26 12:06:37

标签: scala predictionio

我想打印一个集合的内容,并且尝试了mkString方法,但是它仍然使对象的内容不正确。

我的代码: 打包org.template

import org.apache.predictionio.controller.LServing

class Serving
  extends LServing[Query, PredictedResult] {

  override
  def serve(query: Query,
    predictedResults: Seq[PredictedResult]): PredictedResult = {

    println(predictedResults.mkString("\n"))
    predictedResults.head
  }

}

响应:

predictedResult([Lorg.template.ItemScore;@2fb3a837,[Lorg.template.Rule;@5cfc70a8)

PredictedResult类的定义:

package org.template

import org.apache.predictionio.controller.EngineFactory
import org.apache.predictionio.controller.Engine

// Query most similar (top num) items to the given
case class Query(items: Set[String], num: Int) extends Serializable

case class PredictedResult(itemScores: Array[ItemScore], rules: Array[Rule]) extends Serializable

1 个答案:

答案 0 :(得分:3)

如果PredictedResult是这样的案例类

  case class PredictedResult(value: String)
  val predictedResults = List(PredictedResult("aaa"), PredictedResult("bbb"))
  println(predictedResults.mkString("\n"))

然后我们会得到很好的输出

PredictedResult(aaa)
PredictedResult(bbb)

但是如果是像这样的普通班级

  class PredictedResult(value: String)
  val predictedResults = List(new PredictedResult("aaa"), new PredictedResult("bbb"))
  println(predictedResults.mkString("\n"))

然后我们得到

example.Hello$PredictedResult@566776ad
example.Hello$PredictedResult@6108b2d7

要获得常规类的漂亮输出,我们需要像这样重写其toString方法

  class PredictedResult(value: String) {
    override def toString: String = s"""PredictedResult($value)"""
  }

现在输出

PredictedResult(aaa)
PredictedResult(bbb)

解决我们的评论

  case class Rule(v: String)
  case class ItemScore(v: Int)
  case class PredictedResult(itemScores: Array[ItemScore], rules: Array[Rule]) {
    override def toString: String =
      s"""
        |PredictedResult(Array(${itemScores.mkString(",")}, Array(${rules.mkString(",")}))
      """.stripMargin
  }
  val predictedResults = List(PredictedResult(Array(ItemScore(42), ItemScore(11)), Array(Rule("rule1"), Rule("rule2"))))
  println(predictedResults.mkString("\n"))

输出

PredictedResult(Array(ItemScore(42),ItemScore(11), Array(Rule(rule1),Rule(rule2)))

如果我们像这样从Array更改为List

  case class Rule(v: String)
  case class ItemScore(v: Int)
  case class PredictedResult(itemScores: List[ItemScore], rules: List[Rule])
  val predictedResults = List(PredictedResult(List(ItemScore(42), ItemScore(11)), List(Rule("rule1"), Rule("rule2"))))
  println(predictedResults.mkString("\n"))

然后我们可以立即获得很好的输出,而无需覆盖toString

PredictedResult(List(ItemScore(42), ItemScore(11)),List(Rule(rule1), Rule(rule2)))