首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >带有Vegas的Jupyter Notebook (Scala,kernel - Apache Toree),Graph不显示数据

带有Vegas的Jupyter Notebook (Scala,kernel - Apache Toree),Graph不显示数据
EN

Stack Overflow用户
提问于 2019-02-01 14:05:06
回答 2查看 1K关注 0票数 1

我使用的是Jupyter (内核- Apache Torre) for Analytics,使用Apache Spark/Scala。为了可视化,我尝试使用use Vegas (github - https://github.com/vegas-viz/Vegas)

当我使用示例维加斯代码时-没有使用维加斯Spark扩展,它工作得很好(请看附件的截图)

然而,对于DataFrames,它似乎没有显示图形。(即图形未显示数据)

这是代码-

代码语言:javascript
复制
%AddDeps org.vegas-viz vegas_2.11 0.3.11 --transitive

%AddDeps org.vegas-viz vegas-spark_2.11 0.3.11

import vegas._
import vegas.render.WindowRenderer._
import vegas.data.External._
import vegas.sparkExt._

val seq = Seq(("a", 16), ("b", 77), ("c", 45), ("d",101),("e", 132),("f", 166),("g", 51))
val df = seq.toDF("id", "value")

df.show()

+---+-----+
| id|value|
+---+-----+
|  a|   16|
|  b|   77|
|  c|   45|
|  d|  101|
|  e|  132|
|  f|  166|
|  g|   51|
+---+-----+

val usingSparkdf = Vegas("UsingSpark")
  .withDataFrame(df1)
  .encodeX("id")
  .encodeY("value")
  .mark(Bar)

usingSparkdf.show

我在这里做错了什么?

这是包含Scala扩展的正确方式吗?

代码语言:javascript
复制
 %AddDeps org.vegas-viz vegas-spark_2.11 0.3.11
EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2019-02-11 15:14:23

我能够解决这个问题,encodeX,encodeY应该有指定的(统计)数字类型,即Quant,Nom或Ord,以及列名。

下面的代码运行良好。

代码语言:javascript
复制
 val usingSparkdf = Vegas("UsingSpark")
      .withDataFrame(df1)
      .encodeX("id", Nom)
      .encodeY("value", Quant)
      .mark(Bar)

usingSparkdf.show
票数 0
EN

Stack Overflow用户

发布于 2019-07-03 04:33:15

代码语言:javascript
复制
package al.da.vg

object vegas_spark extends App {

  val conf = new SparkConf().setAppName("Vegas_Spark").setMaster("local[*]")
  val sc = new SparkContext(conf)
  val spark = SparkSession.builder().config(conf).appName("Vegas_Spark").getOrCreate()
  val sqlContext = new SQLContext(sc)
  import sqlContext.implicits._

  spark.sparkContext.setLogLevel("WARN")


  val seq1 = Seq(
    Map("a" -> "A", "b" -> 28), Map("a" -> "B", "b" -> 55), Map("a" -> "C", "b" -> 43),
    Map("a" -> "D", "b" -> 91), Map("a" -> "E", "b" -> 81), Map("a" -> "F", "b" -> 53),
    Map("a" -> "G", "b" -> 19), Map("a" -> "H", "b" -> 87), Map("a" -> "I", "b" -> 52))

  val df1 = seq1.toDF("a", "b")

  df1.show()

val usingSparkdf1 = Vegas("Vegas_Spark")
  .withDataFrame(df1)
  .encodeX("a", Ordinal)
  .encodeY("b", Quantitative)
  .mark(Bar)
  .show

}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54473744

复制
相关文章

相似问题

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