首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >VertexRDD给出类型错配错误

VertexRDD给出类型错配错误
EN

Stack Overflow用户
提问于 2016-12-16 17:15:05
回答 1查看 270关注 0票数 1

我正在运行下面的代码,试图在Apache中在GraphX中创建一个图形。

代码语言:javascript
复制
import org.apache.spark.SparkConf

import org.apache.spark.SparkContext

import org.apache.spark.graphx.GraphLoader 

import org.apache.spark.graphx.Graph

import org.apache.spark.rdd.RDD
import org.apache.spark.graphx.VertexId

//loads file from the array

val lines = sc.textFile("hdfs://moonshot-ha-nameservice/data/google-plus/2309.graph");

//maps lines and takes the first 21 characters of each line which is the node.

val result = lines.map( line => line.substring(0,20))

//creates a new variable with each node followed by a long .

val result2 = result.map(word => (word,1L).toLong)

//where i am getting an error

val vertexRDD: RDD[(Long,Long)] = sc.parallelize(result2)

我得到了以下错误:

代码语言:javascript
复制
 error: type mismatch;

 found   : org.apache.spark.rdd.RDD[(Long, Long)]

 required: Seq[?]

Error occurred in an application involving default arguments.
         val vertexRDD: RDD[(Long, Long)] = sc.parallelize(result2)
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-12-16 17:44:05

首先,您的地图可以简化为以下代码:

代码语言:javascript
复制
val vertexRDD: RDD[(Long, Long)] = 
  lines.map(line => (line.substring(0, 17).toLong, 1L))

现在,您的错误是:您不能用RDD调用sc.parallelize。您的vertexRDD已经由result2定义。然后,您可以使用result2和EdgesRDD创建图形:

代码语言:javascript
复制
val g = Graph(result2, edgesRDD)

或者,如果使用我的建议:

代码语言:javascript
复制
val g = Graph(vertexRDD, edgesRDD)
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/41189330

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档