我正在使用ggplot
绘制geom_point
。 x轴将是个人' ID和y轴是变量A.如何在不重叠标签的情况下在x轴上绘制所有和单个ID值? ID可能不是连续的。
df样本(实际行长得多)
> df
ID A
1 4
2 12
3 45
5 1
情节代码:
ggplot(df, aes(x = ID, y = A)) + geom_point()
以上代码的间隔为x轴,但不显示个人ID。
谢谢!
答案 0 :(得分:22)
这是你正在寻找的吗?
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)
这将生成此图像:
因此,您将获得每个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")
此方法的优点是您不会从丢失的ID中获取空格
EDIT2:关于重叠标签的问题:我猜测它来自要绘制的大量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")
导致了这个:
如果无法隐藏标签,则可以将绘图拆分为子图。
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")
导致了这个: