Warning: file_get_contents(/data/phpspider/zhask/data//catemap/3/apache-spark/6.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Apache spark 图形可视化_Apache Spark_Visualization_Spark Graphx - Fatal编程技术网

Apache spark 图形可视化

Apache spark 图形可视化,apache-spark,visualization,spark-graphx,Apache Spark,Visualization,Spark Graphx,我正在寻找一种方法来可视化Spark的Graphx中构建的图形。据我所知,Graphx没有任何可视化方法,因此我需要将数据从Graphx导出到另一个图形库,但我被困在这里。我发现这个网站: 但这没用。我应该使用哪个库以及如何导出图形。所以您可以这样做 从保存到gexf图形交换格式代码 使用中的GEXF插件加载文件 例如: 您可以从中使用或d3。查看Elijah Meeks的D3.js和Michael S.Malak的Spark GraphX 试一试,如下所示,从scala中的齐柏林飞艇和js借用

我正在寻找一种方法来可视化Spark的Graphx中构建的图形。据我所知,Graphx没有任何可视化方法,因此我需要将数据从Graphx导出到另一个图形库,但我被困在这里。我发现这个网站:
但这没用。我应该使用哪个库以及如何导出图形。

所以您可以这样做

从保存到gexf图形交换格式代码 使用中的GEXF插件加载文件 例如:

您可以从中使用或d3。查看Elijah Meeks的D3.js和Michael S.Malak的Spark GraphX

试一试,如下所示,从scala中的齐柏林飞艇和js借用:


您可以使用echats,这是一种简单的工具,用于可视化图形。链接:


您只能从远程url获取json数据,并可视化您的数据

如果您使用的是GRPAHRAMES,那么我已经修改了@Karol Sudol在其GraphFrames答案中提供的代码:

    def drawGraph[vertices:ClassTag,relations:ClassTag](g:GraphFrame) = {

    val u = java.util.UUID.randomUUID
    val v = g.vertices.select("id")


    val vertexes: Array[String] = g.vertices.select("id").rdd.map(x => x(0).toString).collect()

    val edges: Array[Array[String]] = g.edges.select("src", "dst").rdd.map(r => Array(r(0).toString, r(1).toString)).collect()

    val edgeCreation = edges.map{ edgeArray =>
   "{source:nodes["+ vertexes.indexOf(edgeArray(0).trim()) +"],target:nodes["+ vertexes.indexOf(edgeArray(1).trim())+"]}"
  }


  println("""
    <!DOCTYPE html>
     <html lang="en">
     <head>
     <meta charset="utf-8">
     <title>Graph</title>
     <div id='a""" + u + """' style='width:960px; height:500px'></div>
    <style>
    .node circle { fill: gray; }
    .node text { font: 10px sans-serif;        
    text-anchor: middle;
    fill: white; }
    line.link { stroke: gray;
    stroke-width: 1.5px; }
    </style>
    <script src="https://d3js.org/d3.v3.min.js"></script>
    </head>
    <body>
    <script>
    var width = 960, height = 500;
    var svg = d3.select("#a""" + u + """").append("svg")
    .attr("width", width).attr("height", height);
    var nodes = [""" + vertexes.map("{id:\"" + _ + "\"}").mkString(",") + """];
    var links = ["""+ edgeCreation.mkString(",") + """];
    var link = svg.selectAll(".link").data(links);
    link.enter().insert("line", ".node").attr("class", "link");
    var node = svg.selectAll(".node").data(nodes);
    var nodeEnter = node.enter().append("g").attr("class", "node")
    nodeEnter.append("circle").attr("r", 8);
    nodeEnter.append("text").attr("dy", "0.35em")
     .text(function(d) { return d.id; });
    d3.layout.force().linkDistance(50).charge(-200).chargeDistance(300)
    .friction(0.95).linkStrength(0.5).size([width, height])
    .on("tick", function() {
    link.attr("x1", function(d) { return d.source.x; })
      .attr("y1", function(d) { return d.source.y; })
      .attr("x2", function(d) { return d.target.x; })
      .attr("y2", function(d) { return d.target.y; });
    node.attr("transform", function(d) {
    return "translate(" + d.x + "," + d.y + ")";
    });
    }).nodes(nodes).links(links).start();
    </script>
    </body>
    </html>
     """)

}

您需要将图形的顶点和边转换为所需的格式。这是一个将数据帧转换为图表格式的repo。另一个选项是将图形保存为GEXF格式,并将其加载到Gephi可视化系统中。不幸的是,GraphX本机不支持这种格式,但您可以尝试自己实现它。
import org.apache.spark.graphx._
import scala.reflect.ClassTag

def drawGraph[VD:ClassTag,ED:ClassTag](g:Graph[VD,ED]) = {

val u = java.util.UUID.randomUUID
val v = g.vertices.collect.map(_._1)
println("""%html
<div id='a""" + u + """' style='width:960px; height:500px'></div> 
<style>
.node circle { fill: gray; }
.node text { font: 10px sans-serif;
     text-anchor: middle;
     fill: white; }
line.link { stroke: gray;
    stroke-width: 1.5px; }
</style>
<script src="//d3js.org/d3.v3.min.js"></script>
<script>
.var width = 960, height = 500;
var svg = d3.select("#a""" + u + """").append("svg")
.attr("width", width).attr("height", height);
var nodes = [""" + v.map("{id:" + _ + "}").mkString(",") + """];
var links = [""" + g.edges.collect.map(
e => "{source:nodes[" + v.indexWhere(_ == e.srcId) + 
"],target:nodes[" +
v.indexWhere(_ == e.dstId) + "]}").mkString(",") + """];
var link = svg.selectAll(".link").data(links);
link.enter().insert("line", ".node").attr("class", "link");
var node = svg.selectAll(".node").data(nodes);
var nodeEnter = node.enter().append("g").attr("class", "node")
nodeEnter.append("circle").attr("r", 8);
nodeEnter.append("text").attr("dy", "0.35em")
 .text(function(d) { return d.id; });
d3.layout.force().linkDistance(50).charge(-200).chargeDistance(300)
.friction(0.95).linkStrength(0.5).size([width, height])
.on("tick", function() {
link.attr("x1", function(d) { return d.source.x; })
  .attr("y1", function(d) { return d.source.y; })
  .attr("x2", function(d) { return d.target.x; })
  .attr("y2", function(d) { return d.target.y; });
node.attr("transform", function(d) {
return "translate(" + d.x + "," + d.y + ")";
});
}).nodes(nodes).links(links).start();
</script>
 """)
 }
    def drawGraph[vertices:ClassTag,relations:ClassTag](g:GraphFrame) = {

    val u = java.util.UUID.randomUUID
    val v = g.vertices.select("id")


    val vertexes: Array[String] = g.vertices.select("id").rdd.map(x => x(0).toString).collect()

    val edges: Array[Array[String]] = g.edges.select("src", "dst").rdd.map(r => Array(r(0).toString, r(1).toString)).collect()

    val edgeCreation = edges.map{ edgeArray =>
   "{source:nodes["+ vertexes.indexOf(edgeArray(0).trim()) +"],target:nodes["+ vertexes.indexOf(edgeArray(1).trim())+"]}"
  }


  println("""
    <!DOCTYPE html>
     <html lang="en">
     <head>
     <meta charset="utf-8">
     <title>Graph</title>
     <div id='a""" + u + """' style='width:960px; height:500px'></div>
    <style>
    .node circle { fill: gray; }
    .node text { font: 10px sans-serif;        
    text-anchor: middle;
    fill: white; }
    line.link { stroke: gray;
    stroke-width: 1.5px; }
    </style>
    <script src="https://d3js.org/d3.v3.min.js"></script>
    </head>
    <body>
    <script>
    var width = 960, height = 500;
    var svg = d3.select("#a""" + u + """").append("svg")
    .attr("width", width).attr("height", height);
    var nodes = [""" + vertexes.map("{id:\"" + _ + "\"}").mkString(",") + """];
    var links = ["""+ edgeCreation.mkString(",") + """];
    var link = svg.selectAll(".link").data(links);
    link.enter().insert("line", ".node").attr("class", "link");
    var node = svg.selectAll(".node").data(nodes);
    var nodeEnter = node.enter().append("g").attr("class", "node")
    nodeEnter.append("circle").attr("r", 8);
    nodeEnter.append("text").attr("dy", "0.35em")
     .text(function(d) { return d.id; });
    d3.layout.force().linkDistance(50).charge(-200).chargeDistance(300)
    .friction(0.95).linkStrength(0.5).size([width, height])
    .on("tick", function() {
    link.attr("x1", function(d) { return d.source.x; })
      .attr("y1", function(d) { return d.source.y; })
      .attr("x2", function(d) { return d.target.x; })
      .attr("y2", function(d) { return d.target.y; });
    node.attr("transform", function(d) {
    return "translate(" + d.x + "," + d.y + ")";
    });
    }).nodes(nodes).links(links).start();
    </script>
    </body>
    </html>
     """)

}