ggplot2折线图给出“geom_path:每组只包含一个观察。你需要调整群体审美吗?“

使用此数据框(“df”):


year pollution

1 1999 346.82000

2 2002 134.30882

3 2005 130.43038

4 2008  88.27546

我尝试创建这样的折线图:


  plot5 <- ggplot(df, aes(year, pollution)) +

           geom_point() +

           geom_line() +

           labs(x = "Year", y = "Particulate matter emissions (tons)", title = "Motor vehicle emissions in Baltimore")

我得到的错误是:


geom_path:每组只包含一个观察。你需要调整群体美感吗?


即使我想要折线图,图表也会显示为散点图。我试图取代geom_line()有geom_line(aes(group = year)),但没有奏效。


在答案中,我被告知要将年份转换为因子变量。我做了,问题仍然存在。这是输出str(df)和dput(df):


'data.frame':   4 obs. of  2 variables:

 $ year     : num  1 2 3 4

 $ pollution: num [1:4(1d)] 346.8 134.3 130.4 88.3

  ..- attr(*, "dimnames")=List of 1

  .. ..$ : chr  "1999" "2002" "2005" "2008"


structure(list(year = c(1, 2, 3, 4), pollution = structure(c(346.82, 

134.308821199349, 130.430379885892, 88.275457392443), .Dim = 4L, .Dimnames = list(

    c("1999", "2002", "2005", "2008")))), .Names = c("year", 

"pollution"), row.names = c(NA, -4L), class = "data.frame")


阿晨1998
浏览 1049回答 3
3回答

犯罪嫌疑人X

您只需要添加group = 1到ggplot或geom_line aes()中。对于折线图,必须对数据点进行分组,以便知道要连接的点。在这种情况下,它很简单 - 所有点都应该连接,所以group = 1。当使用更多变量并绘制多行时,行的分组通常由变量完成。尝试这个:plot5 <- ggplot(df, aes(year, pollution, group = 1)) +&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;geom_point() +&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;geom_line() +&nbsp; &nbsp; &nbsp; &nbsp; &nbsp;labs(x = "Year", y = "Particulate matter emissions (tons)",&nbsp;&nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; &nbsp; title = "Motor vehicle emissions in Baltimore")

繁花不似锦

您得到此错误,因为您的一个变量实际上是一个因子变量。执行str(df)&nbsp;检查这个。然后执行此双变量更改以保留年份数而不是转换为“1,2,3,4”级别数:df$year <- as.numeric(as.character(df$year))编辑:看来你的data.frame有一个类“array”的变量,它可能会导致pb。然后尝试:df <- data.frame(apply(df, 2, unclass))并再次策划?
打开App,查看更多内容
随时随地看视频慕课网APP