Java事件日志记录(分析)库有一个方法,它接受事件名称,然后是字符串的varargs列表,如下所示:
Analytics.event("my event name", "key1", "value1", "key2", "value2" ...)
我已将我的事件参数收集到像
这样的地图中Map("key1" -> "value1", "key2" -> "value2" ...)
现在必须有一种方法可以展平Map
以列出键和值交替的位置,然后将其提供给事件方法。我有几个猜测,比如转换Map
以列出List
Tuple
的{{1}},但调用.flatten就是说
No implicit view available from (java.lang.String, java.lang.String) => scala.collection.TraversableOnce[B]
我在这里缺少什么?
答案 0 :(得分:6)
您可以使用flatMap将每个键/值对映射到包含两个元素的列表,然后连接这些列表。
scala> Map("k1" -> "v1", "k2" -> "v2")
res0: scala.collection.immutable.Map[java.lang.String,java.lang.String] = Map(k1 -> v1, k2 -> v2)
scala> res0.flatMap { case (k,v) => k::v::Nil }
res1: scala.collection.immutable.Iterable[java.lang.String] = List(k1, v1, k2, v2)
完成后,您只需将列表传递给事件方法:
Analytics.event("my event name", res1:_*)
答案 1 :(得分:6)
您可以使用: _*
运算符:
def event(name: String, values: String*) {/*...*/}
val params = Map("key1" -> "value1", "key2" -> "value2")
val paramsArr = params flatMap {case(k, v) => List(k, v)} toArray
event("name", paramsArr: _*)
不确定这是否适用于Java varargs(让我们知道!)
答案 2 :(得分:1)
val m = Map ("key1" -> "value1", "key2" -> "value2", "k3"-> "v3")
val li = m.map ((e)=> List (e._1, e._2)).flatten.toSeq
event ("name", li: _*)