我有一个包含以下数据的CSV文件:
user,Measurement1,Measurement2,Measurement3,group
1,0.1,0.7,0.2,3
2,0.3,0.3,0.4,2
3,0.3,0.3,0.4,2
我需要为每个用户绘制一条线。x轴可以只是1、2、3(每个测量点标记为before、at、after,但我稍后可以处理标签)。颜色将由组列设置。我找到了一个类似于我所需的图表,但我不想使用用户代码作为x值。
我有一个包含以下数据的CSV文件:
user,Measurement1,Measurement2,Measurement3,group
1,0.1,0.7,0.2,3
2,0.3,0.3,0.4,2
3,0.3,0.3,0.4,2
我需要为每个用户绘制一条线。x轴可以只是1、2、3(每个测量点标记为before、at、after,但我稍后可以处理标签)。颜色将由组列设置。我找到了一个类似于我所需的图表,但我不想使用用户代码作为x值。
ggplot
喜欢使用“长格式”的数据,即每个维度都有一列,每个观测值都有一行。您的数据目前是“宽格式”。使用 reshape
包将其转换为“长格式”。
我理解正确吗?您希望将Measurement1、Measurement2和Measurement3放在x轴上吗?(这样,在您的数据中,用户1的线将从0.1到0.7到0.2?如果是这样,您需要像这样做:
require(reshape)
#Recreate your data frame
user <- gl(3, 1)
Meas1 <- c(0.7, 0.3, 0.3)
Meas2 <- c(0.7, 0.3, 0.3)
Meas3 <- c(0.2, 0.4, 0.4)
group <- c(3, 2, 2)
df <- data.frame(user=user, Meas1=Meas1, Meas2=Meas2, Meas3=Meas3, group=group)
#'melt' the data frame into long format
dfm <- melt(df, id.vars=c("user", "group"))
ggplot(dfm, aes(x=as.numeric(variable), y=value, colour=user)) + geom_line()