accessing data of the plot within ggtitle

后端 未结 2 1372
失恋的感觉
失恋的感觉 2021-02-08 23:16

I am wondering if it is somehow possible to access the columns of the provided data within a ggplot2 graph for the title. So something like that:

gg         


        
相关标签:
2条回答
  • 2021-02-08 23:39

    Here's two ways I've done this using split. You can use split to split your dataframe into a named list of dataframes, based on a variable. So calling split(mpg, .$manufacturer) gives you a list of dataframes, where each dataframe is associated with a manufacturer, e.g. split_df$audi is the dataframe of all observations made by Audi.

    library(dplyr)
    library(purrr)
    library(ggplot2)
    
    split_df <- split(mpg, .$manufacturer)
    

    First way you could do this is to just call ggplot on a single item in the list. Since the list is named, names(split_df)[1] will give you the name, "audi".

    ggplot(split_df[[1]], aes(x = hwy, y = displ, label = model)) + 
        geom_point() + 
        geom_text(data = . %>% filter(hwy > 28)) +
        ggtitle(names(split_df)[1])
    

    That's kinda cumbersome, especially if you want plots for multiple manufacturers. When I've done this, I've used the map functions from purrr. What's really cool is imap, which maps over both the list and its names. Here I'm making a list of plots by mapping over the list of dataframes; each plot gets a title from the name of that list item.

    plots <- imap(split_df, function(df, manufacturer) {
        ggplot(df, aes(x = hwy, y = displ, label = model)) +
            geom_point() +
            geom_text(data = . %>% filter(hwy > 28)) +
            ggtitle(manufacturer)
    })
    
    plots$audi
    

    Then I can pull up a specific item from that list of plots. This is also handy for if you need to use walk to map over them and save every plot or a subset of plots, or if you need to use a grid function to arrange them into output, or really anything else cool that purrr is great for.

    0 讨论(0)
  • 2021-02-08 23:48

    I would try the following as it is not possible to pipe outside aes().

    ggplot(mpg %>% filter(manufacturer == 'audi'), 
           aes(x = hwy, y = displ, label = model)) + 
      geom_point() + 
      geom_text(data = . %>% filter(hwy > 28)) +
      facet_wrap(~manufacturer)+
      theme(strip.background = element_blank(),
            strip.text = element_text(hjust = 0, size = 14))
    

    The idea is to use a facet with empty strip background. If there are more names or variables one has to create an extra faceting variable using e.g. mutate(gr = "title")

    mpg %>% 
      mutate(title="This is my plot") %>% 
    ggplot(aes(x = hwy, y = displ, col=manufacturer)) + 
      geom_point() + 
      facet_wrap(~title)+
      theme(strip.background = element_blank(),
            strip.text = element_text(hjust = 0, size = 14))
    

    Edit

    As you asked a second question here are two solutions for creating individual plots for each group

    # first solution
    p <- mpg %>%
      group_by(manufacturer) %>% 
         do(plots= ggplot(., aes(cyl, displ)) +
          geom_point() + 
          ggtitle(unique(.$manufacturer))
       )
    p %>% slice(1) %>% .$plots
    
    
    # second solution
    mpg %>%
      nest(-manufacturer) %>%
      mutate(plot = map2(data, manufacturer, ~ggplot(data=.x,aes(cyl, displ))+
               geom_point() +
               ggtitle(.y))) %>% 
      slice(1) %>% .$plot 
    

    Or save the data using

    map2(paste0(p$manufacturer, ".pdf"), p$plots, ggsave)
    
    0 讨论(0)
提交回复
热议问题