ggplot删除特定的x轴标签

问题描述 投票:1回答:3
library(tidyverse)

df <- data.frame(date = as.Date(c("2017-12-01", "2018-01-01", "2018-02-01", 
                                  "2018-03-01", "2018-04-01", "2018-05-01", 
                                  "2018-06-01", "2018-07-01", "2018-08-01", 
                                  "2018-09-01", "2018-10-01", "2018-11-01")), 
                 value = c(0.567859562, 0.514907158, 0.035399304, 0.485728823, 
                           0.925127361, 0.237531067, 0.301930968, 0.133373326, 
                           0.082275426, 0.464255614, 0.2366749, 0.652084264))

ggplot(df, aes(date, value)) + 
  geom_col() + 
  scale_x_date(date_breaks = "1 month", 
                 date_labels = "%b") + 
  theme(axis.text.x = element_text(angle = 90, vjust = 0.3))

我想保持下面所示的情节,完全一样,有两个例外。我想删除x轴标签上的第一个Nov和x轴标签上的最后一个Dec。我在上面的代码块中添加了coord_cartesian(xlim = as.Date(c("2017-12-01", "2018-11-01"))),但这消除了我x轴任意一端的“空格”填充。

如何告诉ggplot删除第一个和最后一个x轴标签的文本?这将是第一个Nov和最后一个Dec。请注意,这些在我的df数据框中根本不存在,因此dplyr过滤器可能不起作用。

enter image description here

r ggplot2
3个回答
1
投票

我想这就是你想要的。 date_breaks是不必要的。

ggplot(df, aes(date, value)) + 
  geom_col() + 
  scale_x_date(date_labels = "%b", breaks = df$date) + 
  theme(axis.text.x = element_text(angle = 90, vjust = 0.3))

Resulting plot


2
投票

你可以通过使用seq.date设置中断来实现你想要的:

library(tidyverse);library(lubridate)

df <- data.frame(date = as.Date(c("2017-12-01", "2018-01-01", "2018-02-01", 
                                  "2018-03-01", "2018-04-01", "2018-05-01", 
                                  "2018-06-01", "2018-07-01", "2018-08-01", 
                                  "2018-09-01", "2018-10-01", "2018-11-01")), 
                 value = c(0.567859562, 0.514907158, 0.035399304, 0.485728823, 
                           0.925127361, 0.237531067, 0.301930968, 0.133373326, 
                           0.082275426, 0.464255614, 0.2366749, 0.652084264))



ggplot(df, aes(date, value)) + 
  geom_col() + 
  scale_x_date(
               date_labels = "%b",
               breaks = seq.Date(ymd("2017-12-01"),ymd("2018-11-01"), by = "month")) + 
  theme(axis.text.x = element_text(angle = 90, vjust = 0.3))

enter image description here


0
投票

我建议在R中研究Lubridate软件包 - 你可以将任何凌乱的日期值转换为适当的POSIXT格式,并且还可以非常容易地提取月份信息 - 您还可以将这些日期转换为实际月份的单个列,并使用作为你的轴标签,这是更清洁,因为你会有一个额外的相应月份的列 - 你也可以根据那个月填写并做一些其他很酷的东西!

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