是否可以将geom_table()与facet_grid()一起使用?

问题描述 投票:0回答:2

最近我发现了 ggpmisc 包中的函数

geom_table()
,它允许您将表格放入绘图中。但我不知道如何将不同的表格放入网格图中。

我有这个 df 和情节:

library(lubridate)
library(ggplot2)
library(ggpmisc)

Date <- c("2010-01-28", "2010-02-28", "2010-03-28", 
          "2010-04-28", "2010-05-28", "2010-06-28", 
          "2010-07-28", "2010-08-28", "2010-09-28", 
          "2010-10-28")

Date <- as_date(Date)

Country <- rep("Japan", 10)
A <- runif(10, min=30, max=90)
B <- runif(10, min = 1, max = 15)


df <- data.frame(Date, Country, A, B)


df %>% pivot_longer(-c(Date, Country)) %>%
  ggplot(aes(x=Date,y=value,group=1,color=Country))+ 
  geom_line(size = 0.9) +
  facet_grid(name~Country, scales = "free", switch = "y") 

我也有这两个表,tableA和tableB:

Time <- c("Today", "Yesterday", "One week ago")

Value_A <- 10:12
Value_B <- 1:3

tableA <- data.frame(Time, Value_A)
tableB <- data.frame(Time, Value_B)
  

如何将 tableA 放在顶部图表中,将 tableB 放在底部图表中?

如果有人可以提供帮助,我将不胜感激:)

r ggplot2 facet-grid
2个回答
2
投票

您需要创建一个小数据框,在列表列中托管您的

tableA
tableB

d <- tibble(x = c(0.95, 0.95), y = c(0.95, 0.95),
            name = c("A", "B"), tb = list(tableA, tableB))

df %>% pivot_longer(-c(Date, Country)) %>%
  ggplot(aes(x=Date,y=value,group=1,color=Country))+ 
  geom_line(size = 0.9) +
  geom_table_npc(data = d, aes(npcx = x, npcy = y, label = tb)) +
  facet_grid(name~Country, scales = "free", switch = "y") 


0
投票

@Allan Cameron,您是否有机会回答我的类似问题?谢谢您的帮助!

© www.soinside.com 2019 - 2024. All rights reserved.