如何将表格添加到ggplot?

ℕʘʘ*_*ḆḽḘ 5 r ggplot2 flextable patchwork

我正在尝试将(在单个图表中)常规ggplot图表与使用flextable.

考虑以下示例:

library(tidyverse)
library(patchwork)

mydf <- tibble(a = c(1,2,3,4,5,4),
               b = c(4,4,4,3,3,3))

p1 <- mydf %>% ggplot(aes(x = a, y = b, color = as.factor(b))) + geom_point()

p2 <- mydf %>% flextable::flextable()
Run Code Online (Sandbox Code Playgroud)

p2 好像

在此处输入图片说明

但不幸的是我不能将它与 p1

> p1 + p2
Error: Don't know how to add p2 to a plot
Run Code Online (Sandbox Code Playgroud)

我们可以做什么?谢谢!

Dav*_*hel 7

您可以使用 fonctionflextable::as_raster从 flextable 获取栅格,然后将 with 添加annotation_custom到空的 ggplot 对象。

library(ggplot2)
library(flextable)
library(grid)
library(cowplot)
library(tidyverse)

mydf <- tibble(a = c(1,2,3,4,5,4),
               b = c(4,4,4,3,3,3))

p1 <- mydf %>% ggplot(aes(x = a, y = b, color = as.factor(b))) + geom_point()

ft_raster <- mydf %>% flextable::flextable() %>% 
  as_raster()

p2 <- ggplot() + 
  theme_void() + 
  annotation_custom(rasterGrob(ft_raster), xmin=-Inf, xmax=Inf, ymin=-Inf, ymax=Inf)

cowplot::plot_grid(p1, p2, nrow = 2, ncol = 1, rel_heights = c(4, 1) )
Run Code Online (Sandbox Code Playgroud)

在此处输入图片说明

文档在这里:https : //davidgohel.github.io/flextable/articles/offcran/images.html


Bap*_*Das 5

有以下2种方式

library(tidyverse)
library(ggpmisc)

mydf <- tibble(a = c(1,2,3,4,5,4),
               b = c(4,4,4,3,3,3))

p1 <- mydf %>% ggplot(aes(x = a, y = b, color = as.factor(b))) + geom_point()
p1 + annotate(geom = "table", x = 4.5, y = 3.5, label = list(mydf), 
           vjust = 1, hjust = 0)
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

p1 + geom_table_npc(data = mydf, label = list(mydf),npcx = 0.05, npcy = 0.90, hjust = 0, vjust = 1)
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述


Tun*_*ung 5

tableGrobgridExtra包中也可以使用

library(tidyverse)
library(grid)
library(gridExtra)

mydf <- tibble(a = c(1,2,3,4,5,4),
               b = c(4,4,4,3,3,3))

p1 <- mydf %>% ggplot(aes(x = a, y = b, color = as.factor(b))) + geom_point()

mytheme <- gridExtra::ttheme_default(
  core = list(padding = unit(c(2.5, 2.5), "mm")))
tbl <- tableGrob(mydf, theme = mytheme, rows = NULL)

grid.arrange(p1,
             tbl,
             nrow = 2,
             as.table = TRUE,
             heights = c(4, 1))
Run Code Online (Sandbox Code Playgroud)

reprex 包(v0.3.0)于 2020 年 2 月 21 日创建