带有所有x轴值的ggplot x轴标签

Lum*_*mos 10 axis r ggplot2

我密谋ggplotgeom_point.x轴将是个体ID,y轴是变量A.如何在不重叠标签的情况下在x轴上绘制所有和各个ID值?ID可能不是连续的.

df样本(实际行长得多)

> df
ID     A
1      4
2      12
3      45
5      1
Run Code Online (Sandbox Code Playgroud)

情节代码:

ggplot(df, aes(x = ID, y = A)) + geom_point()
Run Code Online (Sandbox Code Playgroud)

以上代码的间隔为x轴,但不显示个人ID.

谢谢!

bre*_*usn 28

这是你在找什么?

ID <- 1:50
A <- runif(50,1,100)

df <- data.frame(ID,A)

ggplot(df, aes(x = ID, y = A)) + 
  geom_point() + 
  theme(axis.text.x = element_text(angle = 90, vjust = 0.5)) +
  scale_x_continuous("ID", labels = as.character(ID), breaks = ID)
Run Code Online (Sandbox Code Playgroud)

这将产生这个图像:

在此输入图像描述

因此,您将获得每个ID值的标签.如果你想删除网格线(我的口味太多了)你可以通过添加删除它们theme(panel.grid.major = element_blank(), panel.grid.minor = element_blank())

编辑:更简单的方法是使用ID作为情节的一个因素.像这样:

ggplot(df, aes(x = factor(ID), y = A)) + 
  geom_point() + 
  theme(axis.text.x = element_text(angle = 90, vjust = 0.5)) +
  xlab("ID")
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

此方法的优点是您不会从缺少的ID中获取空白空间

编辑2:关于重叠标签的问题:我猜测它来自大量要绘制的ID.我们有几种方法可以解决这个问题.所以我们说你的情节看起来像这样:

在此输入图像描述

一种想法是通过修改轴的break参数来隐藏x轴上的每个第3个标签:

ggplot(df, aes(x = factor(ID), y = A)) + 
  geom_point() + 
  scale_x_discrete(breaks = ID[c(T,F,F)]) +
  theme(axis.text.x = element_text(angle = 90, vjust = 0.5)) +
  xlab("ID")
Run Code Online (Sandbox Code Playgroud)

这导致了这个:

在此输入图像描述

如果无法隐藏标签,则可以将绘图拆分为子图.

df$group <- as.numeric(cut(df$ID, 4))

ggplot(df, aes(x = factor(ID), y = A)) + 
  geom_point() + 
  theme(axis.text.x = element_text(angle = 90, vjust = 0.5)) +
  xlab("ID") +
  facet_wrap(~group, ncol = 1, scales = "free_x")
Run Code Online (Sandbox Code Playgroud)

这导致了这个:

在此输入图像描述