- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我读过一篇similar post on SO ,但无法根据我的具体情况调整答案。我正在处理时间序列数据,并希望将两个不同的数据集合并到同一个图中。虽然我可以将数据合并到一个数据框中,但我真的很想了解如何引用多个数据集。
模拟数据:
require(ggvis)
dfa <- data.frame(
date_a = seq(from= as.Date("2015-06-10"),
to= as.Date("2015-07-01"), by= 1),
val_a = c(2585.150, 2482.200, 3780.186, 3619.601,
0.000, 0.000, 3509.734, 3020.405,
3271.897, 3019.003, 3172.084, 0.000,
0.000, 3319.927, 2673.428, 3331.382,
3886.957, 2859.887, 0.000, 0.000,
2781.443, 2847.377) )
dfb <- data.frame(
date_b = seq(from= as.Date("2015-07-02"),
to= as.Date("2015-07-15"), by= 1),
val_b = c(3250.75429, 3505.43477, 3208.69141,
-2.08175, -27.30244, 3324.62348,
2820.91075, 3250.75429, 3505.43477,
3208.69141, -2.08175, -27.30244,
3324.62348, 2820.91075) )
使用上面提供的数据,我可以使用下面的代码创建单独的图:
单独的地 block :(作品)
dfa %>%
ggvis( x= ~date_a , y= ~val_a, stroke := "black", opacity := 0.5 ) %>%
scale_datetime("x", nice = "month", domain = c(as.Date("2015-06-10"),
as.Date("2015-07-15") )) %>%
layer_lines() %>% layer_points( fill := "black" )
dfb %>%
ggvis( x= ~date_b , y= ~val_b, stroke := "red", opacity := 0.5 ) %>%
scale_datetime("x", nice = "month", domain = c(as.Date("2015-06-10"),
as.Date("2015-07-15") )) %>%
layer_lines() %>% layer_points( fill := "red" )
所需的输出是这两条线(黑色和红色)位于同一绘图上。以下是一些不成功的尝试:
尝试 #1 改编自 SO post :
ggvis( data = dfa, x = ~date_a, y = ~val_a) %>% layer_lines(stroke := "black", opacity := 0.5 ) %>%
layer_lines( data = dfb, x= ~date_b , y= ~val_b, stroke := "red",
opacity := 0.5 ) %>%
scale_datetime("x", nice = "month", domain = c(as.Date("2015-06-10"),
as.Date("2015-07-15") ))
## Error in new_prop.default(x, property, scale, offset, mult, env, event, :
## Unknown input to prop: c(16618, 16619, 16620, 16621, 16622, 16623, 16624, ...
基于RStudio documentation的尝试#2 :
ggvis( data = NULL, x = ~date_a, y = ~val_a) %>%
layer_lines(stroke := "black", opacity := 0.5, data = dfa ) %>%
layer_lines( x= ~date_b , y= ~val_b, stroke := "red",
opacity := 0.5, data = dfb ) %>%
scale_datetime("x", nice = "month", domain = c(as.Date("2015-06-10"),
as.Date("2015-07-15") ))
## Error in func() : attempt to apply non-function
这是 ggplot2 中的简约实现:
require(ggplot2)
ggplot() +
geom_line(data = dfa, aes(x = date_a, y = val_a ), colour = "black") +
geom_line(data = dfb, aes(x = date_b, y = val_b ), colour = "red")
再次,如果有可行的解决方案和简短的解释,我们将不胜感激。预先感谢您的帮助。
最佳答案
嗯,看起来 layer_lines
可能无法正确采用 data
参数。我认为你可以在这里成功使用layer_paths
。它们的工作原理类似,但 layer_paths
按数据顺序工作,因此您需要在绘图之前确保时间序列排列正确。
首先,当我查看layer_paths
基本函数时,它与许多其他图层函数一样,具有特定的数据参数。
layer_paths
function (vis, ..., data = NULL)
{
add_mark(vis, "line", props(..., env = parent.frame()), data,
deparse2(substitute(data)))
}
<environment: namespace:ggvis>
虽然 layer_lines
有用于更多参数的 ...
,但它没有 data
参数,而且看起来不像事情与它一起工作。
layer_lines
function (vis, ...)
{
x_var <- vis$cur_props$x$value
layer_f(vis, function(x) {
x <- auto_group(x, exclude = c("x", "y"))
x <- dplyr::arrange_(x, x_var)
emit_paths(x, props(...))
})
}
<environment: namespace:ggvis>
为了测试,我制作了一个非常基本的图表,尝试使用 layer_lines
中的 data
参数。
ggvis() %>%
layer_lines(data = dfb, x= ~date_b , y= ~val_b, stroke := "red")
此操作失败并出现错误。
Error in func() : attempt to apply non-function
下面是使用 layer_paths
的相同代码:
ggvis() %>%
layer_paths(data = dfb, x= ~date_b , y= ~val_b, stroke := "red")
所以,这是可行的,这意味着只要您按日期对数据集进行排序,只需将 layer_lines
替换为 layer_paths
,您的图形就应该可以正常工作。
ggvis(data = dfa, x = ~date_a, y = ~val_a) %>%
layer_paths(stroke := "black", opacity := 0.5 ) %>%
layer_paths(data = dfb, x = ~date_b , y= ~val_b, stroke := "red",
opacity := 0.5 ) %>%
scale_datetime("x", nice = "month", domain = c(as.Date("2015-06-10"), as.Date("2015-07-15") ))
这对我来说似乎很奇怪,而且我错过了一些东西。我在 ggvis
github page 上没有看到任何开放或已关闭的问题。您可以考虑提交一份。
关于r - ggvis:将多个数据集合并在一个图中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33130831/
我已经搜索过了,所以如果我遗漏了什么,请原谅我。 让我们假设一个包含名称、日期、卡路里的数据框,其中卡路里是该人当天消耗的卡路里总数。 Name Date Calories Amy
我读过一篇similar post on SO ,但无法根据我的具体情况调整答案。我正在处理时间序列数据,并希望将两个不同的数据集合并到同一个图中。虽然我可以将数据合并到一个数据框中,但我真的很想了解
我曾经用 ggplot2 制作交互图,代码如下。现在我想用 ggvis 重现相同的情节,如下所示,它与 ggplto2 输出不同。如何使用 ggvis 获得相同的图? library(ggplot2)
我正在尝试使用 ggvis 中 ggplot2 中的数字复制热图。ggplot2版本是 library(ggplot2) hec % ggvis(~Hair, ~Eye, fill=~Freq)%>%
在ggvis中如何使图例垂直? mtcars %>% ggvis(x = ~wt, y = ~mpg, fill = ~cyl) %>% layer_points() %>% add_legend("
有没有办法在 ggvis 中将标签附加到堆叠条形图? 示例代码: plotData = data.frame(v1 = c("ABC", "ABC", "ABC", "XYX","XYX","X
我正在尝试更改 ggvis 中的刻度标签阴谋。我的数据点是 x = c(1,2,3)和 y = c(1,2,3) .但是,下面的代码会产生完全没有意义的刻度标签! library(dplyr) lib
我的 ggvis 图取决于几个输入字段,它们的工作方式类似于输入数据的过滤器。对于某些组合,结果数据框为空,ggvis 抛出错误并破坏整个应用程序。 我试着把 if(nrow(inputdatafra
我有一个 RStudio Shiny 服务器正在运行,我从 https://github.com/rstudio/ggvis 安装了 ggvis但我无法在服务器中重现任何演示示例。 当我在服务器(3.
ggvis 将根据我传递的因子列自动为我的绘图着色。所以如果我的因子列被命名为“区域”,我可以写这个,它会完美地执行。 names = c("Bacilli", "Actinobacteria", "
我正在从 Excel 迁移到 ggvis 进行数据分析。对于具有两个变量的典型分组条形图,但是我很难情节 条形图并排而不是堆叠 . 以下数据有四个步骤 A、B、C、D,其中“比率”数据来自两个特征 c
使用这个小数据集: df % ggvis(x=~variable, y=~value, fill=~colour) %>% group_by(colour) %>% layer_bars(
我是 R 的新手,因此不得不问你一个基本问题。 我有两个大型面板数据集(60 个变量,每个变量代表 30 个国家,范围从 1950 年到 2013 年)。 60个变量同名,数据可能不同也可能不同。 我
我正在尝试让交互式缩放在 ggvis 中工作,尤其是使用画笔进行缩放。从https://github.com/rstudio/ggvis/issues/143判断我认为这应该有效。 我有以下 Shin
我有多个带有多个段的路径。如何用相同的颜色为每条路径的第 N 段着色? 例如: require(dplyr) require(ggvis) df % group_by(group) %>% ggv
我正在尝试使用 ggvis 为 2014 赛季创建 NFL 赛程强度图表。数据来自 FootballOutsiders.com,稍后我将制作一个 Shiny 应用程序,当它在赛季期间更新时,它会自动从
我想为 ggvis 绘图添加标题。我在任何地方都找不到示例。处理其他 R 图很简单,例如 library(ggplot2) library(ggvis) x % ggvis(~x, ~y) %>% l
嗨,我对 ggvis 中的刻度有点困惑。我想做两件事:一是有一个对数刻度(相当于plot()中的log =“x”)。我也在寻找 xlim=c() 的等效项。在这两种情况下,下面的代码都没有给出预期的结
我正在尝试用 ggvis 制作一个箱线图,但我似乎无法查看一个简单的示例 library(dplyr) library(ggplot2) library(shiny) #I think this is
我正在尝试使用来自不同数据帧的数据在 ggvis 图中添加带有任意文本的图例。我试过使用 add_legend() 但我不知道要使用什么参数。使用 plot() 使用 legend() 函数非常简单,
我是一名优秀的程序员,十分优秀!