次のコードは、以下のように各列に3つの値を持つデータフレームを提供します。上記のコードのApache-Sparkデータフレームの距離の合計
import org.graphframes._
import org.apache.spark.sql.DataFrame
val v = sqlContext.createDataFrame(List(
("1", "Al"),
("2", "B"),
("3", "C"),
("4", "D"),
("5", "E")
)).toDF("id", "name")
val e = sqlContext.createDataFrame(List(
("1", "3", 5),
("1", "2", 8),
("2", "3", 6),
("2", "4", 7),
("2", "1", 8),
("3", "1", 5),
("3", "2", 6),
("4", "2", 7),
("4", "5", 8),
("5", "4", 8)
)).toDF("src", "dst", "property")
val g = GraphFrame(v, e)
val paths: DataFrame = g.bfs.fromExpr("id = '1'").toExpr("id = '5'").run()
paths.show()
val df=paths
df.select(df.columns.filter(_.startsWith("e")).map(df(_)) : _*).show
出力が上記出力において以下::
+-------+-------+-------+
| e0| e1| e2|
+-------+-------+-------+
|[1,2,8]|[2,4,7]|[4,5,8]|
+-------+-------+-------+
与えられ、我々は、各列は3つの値があり、次のように、それらが解釈できることがわかります。
e0 :
source 1, Destination 2 and distance 8
e1:
source 2, Destination 4 and distance 7
e2:
source 4, Destination 5 and distance 8
基本的
e0
、e1
、及びe3
がエッジです。各列の3番目の要素を合計したい、つまり合計距離を取得するために各エッジの距離を加算します。どうすればこれを達成できますか?
はに意味.property' 'ですあなたがアクセスしようとしている列の要素の一般的なプレースホルダですか? –
@ evan058 OPがアクセスしようとするカラムは、Grapframesエッジです。 3つのフィールド( 'src'、' dst'、 'property')を持つ構造体として表現されています。したがって、それは列の要素です。 –