ggplot2 сохранить неиспользуемые уровни barplot


101

Я хочу построить неиспользуемые уровни (то есть уровни, где счетчик равен 0) на моем столбчатом графике, однако неиспользуемые уровни отбрасываются, и я не могу понять, как их сохранить.

df <- data.frame(type=c("A", "A", "A", "B", "B"), group=rep("group1", 5))
df$type <- factor(df$type, levels=c("A","B", "C"))

ggplot(df, aes(x=group, fill=type)) + geom_bar()

В приведенном выше примере я хочу увидеть график C со счетом 0, но он полностью отсутствует ...

Спасибо за любую помощь Ульрик

Редактировать:

Это то, что я хочу

df <- data.frame(type=c("A", "A", "A", "B", "B"), group=rep("group1", 5))
df1 <- data.frame(type=c("A", "A", "A", "B", "B", "A", "A", "C", "B", "B"), group=c(rep("group1", 5),rep("group2", 5)))

df$type <- factor(df$type, levels=c("A","B", "C"))
df1$type <- factor(df1$type, levels=c("A","B", "C"))
df <- data.frame(table(df))

df1 <- data.frame(table(df1))

ggplot(df, aes(x=group, y=Freq, fill=type)) + geom_bar(position="dodge")
ggplot(df1, aes(x=group, y=Freq, fill=type)) + geom_bar(position="dodge")

Угадайте, что решение состоит в том, чтобы вычислить частоты с помощью table (), а затем построить график

Ответы:


68

Вам нужно установить drop = FALSE для обеих шкал (fill и x) следующим образом:

library(ggplot2)
df <- data.frame(type=c("A", "A", "A", "B", "B"), group=rep("group1", 5))
df1 <- data.frame(type=c("A", "A", "A", "B", "B", "A", "A", "C", "B", "B"), group=c(rep("group1", 5),rep("group2", 5)))
df$type <- factor(df$type, levels=c("A","B", "C"))
df1$type <- factor(df1$type, levels=c("A","B", "C"))

plt <- ggplot(df, aes(x=type, fill=type)) + geom_bar(position='dodge') + scale_fill_discrete(drop=FALSE) + scale_x_discrete(drop=FALSE)
plt1 <-  ggplot(df1, aes(x=type, fill=type)) + geom_bar(position='dodge') + scale_fill_discrete(drop=FALSE) + scale_x_discrete(drop=FALSE)

Редактировать:

Я почти уверен, что это работает. Забыл поменять x на type вместо group и position = 'dodge'! Просто вставьте и проверьте. Stat_bin имеет дело с ячейками с нулевым счетчиком. Проверьте документы .


Я думаю, это должен быть ответ на вопрос ОП. Ответ также учитывает пониженный уровень в легенде.
SavedByJESUS

когда я это делаю, он меняет цвета моих полосок. Есть ли способ сохранить оригинальные цвета?
morgan121

71

Это делает то, что вы хотите?

ggplot(df, aes(x=type)) + geom_bar() + scale_x_discrete(drop=FALSE)

введите описание изображения здесь


9

Сбрасывание уровней не работает. Падение уровней в первом примере

library(ggplot2)

df <- data.frame(type=c("A", "A", "A", "B", "B"), group=rep("group1", 5))
df$type <- factor(df$type, levels=c("A","B", "C"))

ggplot(df, aes(x=group, fill=type)) + geom_bar(position="dodge") + scale_x_discrete(drop=FALSE) + scale_fill_discrete(drop=FALSE)

приводит к этому сюжету:

введите описание изображения здесь

Решение находится во втором примере, где частоты вычисляются вручную:

df <- data.frame(type=c("A", "A", "A", "B", "B"), group=rep("group1", 5))
df1 <- data.frame(type=c("A", "A", "A", "B", "B", "A", "A", "C", "B", "B"), group=c(rep("group1", 5),rep("group2", 5)))

df$type <- factor(df$type, levels=c("A","B", "C"))
df1$type <- factor(df1$type, levels=c("A","B", "C"))

df <- data.frame(table(df))
df1 <- data.frame(table(df1))

df$plot = "A"
df1$plot = "B"

df <- rbind(df, df1)

ggplot(df, aes(x=group, y=Freq, fill=type)) + geom_bar(position="dodge", stat="identity") + facet_wrap( ~ plot, scales="free")

Результаты в этом:

введите описание изображения здесь

Последний из них наиболее информативен, так как место занимает категории, там count = 0


1

вы также можете использовать "scale_fill_color", например:

plt <- ggplot(df, aes(x=type, fill=type)) + geom_bar(position='dodge') + scale_x_discrete(drop=FALSE)+
scale_fill_manual(
  values = c(
    "#ff6666",
    "#cc9900",
    "#cc9900",
    ),drop=FALSE)
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.