2

首先,我读取一个文本文件并将其转换为 RDD[(String,(String,Float))]:

val data = sc.textFile(dataInputPath);
val dataRDD:RDD[(String,(String,Float))] = data.map{f=> {
      val temp=f.split("//x01");
      (temp(0),(temp(1),temp(2).toInt ) );
      }
    } ;

然后,我运行以下代码将我的数据转换为 Rating 类型

import org.apache.spark.mllib.recommendation.Rating
val imeiMap = dataRDD.reduceByKey((s1,s2)=>s1).collect().zipWithIndex.toMap;
val docidMap = dataRDD.map( f=>(f._2._1,1)).reduceByKey((s1,s2)=>s1).collect().zipWithIndex.toMap;
val ratings = dataRDD.map{case (imei, (doc_id,rating))=> Rating(imeiMap(imei),docidMap(doc_id),rating)};

但我得到一个错误:

Error:(32, 77) type mismatch;
 found   : String
 required: (String, (String, Float))
    val ratings = dataRDD.map{case (imei, (doc_id,rating))=> Rating(imeiMap(imei),docidMap(doc_id),rating)};

为什么会这样?我认为string已经更改为(String, (String, Float)).

4

2 回答 2

2

这不是关于你的dataRDD,而是关于imeiMap

imeiMap: scala.collection.immutable.Map[(String, (String, Float)),Int] 
于 2018-05-21T09:55:18.690 回答
2

docidMap的key不是String,是Tuple(String, Int)

这是因为您在方法之前有 zipWithIndex .toMap

将此 rdd 作为快速测试的输入:

(String1,( String2,32.0))
(String1,( String2,35.0))



scala> val docidMap = dataRDD.map( f=>(f._2._1,1)).reduceByKey((s1,s2)=>s1).collect().zipWithIndex.toMap;
docidMap: scala.collection.immutable.Map[(String, Int),Int] = Map((" String2",1) -> 0)


val docidMap = dataRDD.map( f=>(f._2._1,1)).reduceByKey((s1,s2)=>s1).collect().toMap;
docidMap: scala.collection.immutable.Map[String,Int] = Map(" String2" -> 1)     

你的也会发生同样的情况imeiMap,看来你也只需zipWithIndex要从那里删除

val imeiMap = dataRDD.reduceByKey((s1,s2)=>s1).collect.toMap
于 2018-05-21T09:56:20.510 回答