在R中反转x轴两次

时间:2017-10-02 12:07:31

标签: r bar-chart reverse

我想要反转x轴两次。现在我简单地反转x轴的范围,我的结果是3,2,1,0而不是0,1,2,3。

我的代码:

temp2 = table(mFT$Vorschlaege, mFT$Bewertung)

barplot(temp2 , main="10 Vorschläge pro Methode", xlab="Bewertung", beside=TRUE, ylim = c(0,40), xlim= c(43,3), col = colours10) 
legend("top", legend = rownames(temp2), fill = colours10)

see my barplot

现在我希望将条形反转为3,2,1和0。 " Vorschlag 1"应该是第一位的" Vorschlag10"最后。

我该怎么做?

2 个答案:

答案 0 :(得分:0)

假设mFT$Vorschlaege是一个因素,您可以颠倒因子级别的顺序。尝试:

mFT$Vorschlaege2 <- factor(mFT$Vorschlaege,levels = levels(mFT$Vorschlaege)[10:1])

这会颠倒您的因子水平的顺序。如果mFT$Vorschlaege不是一个因素,您必须先将其变为一个因素。我重命名变量mFT$Vorschlaege2以避免覆盖原始变量,因此您必须使用新变量重复table命令。

temp2 = table(mFT$Vorschlaege2, mFT$Bewertung)
    barplot(temp2 , main="10 Vorschläge pro Methode", xlab="Bewertung", beside=TRUE, ylim = c(0,40), xlim= c(43,3), col = colours10) 
    legend("top", legend = rownames(temp2), fill = colours10)

如果没有可重复的示例,我无法测试此解决方案,但它可以使用我自己的数据。

答案 1 :(得分:0)

是的,因素是这里的关键。 我使用玩具数据集创建了一个带ggplot2的条形图:

library(ggplot2)

### toy dataset
Vorschlaege <- c("V1", "V3", "V2", "V5", "V4")
Bewertung <- c(100, 20, 30, 40, 50)
df <- data.frame(Vorschlaege, Bewertung)

## define sorting order by factor as you want to have it in your bar chart:
df$Vorschlaege <- factor(df$Vorschlaege, levels = c("V5", "V4", "V3", "V2", "V1"))

ggplot(df, aes(df$Vorschlaege)) + 
  geom_bar(aes(weight = df$Bewertung)) +
  labs(title = "Meine Vorschläge",
       x = "Vorschlag", y = "Bewertung",
       subtitle = "Zeitraum: x bis y", caption = "Quelle: Meine Forschung") +
  theme_bw() ## white background theme