如果这个问题已经得到解答,我提前道歉,但我找不到我需要的东西。 我想从名为data1.dat,data2.dat,...的文件中绘制一些结果。我设法用循环导入数据,但我无法使用循环绘制结果。仅绘制第一个数据的结果。以下是我使用的脚本:
for(i in 1:3){
assign( paste("data", i, sep=""),
read.table(file=paste(paste("data", i, sep=""),"_lambda.dat",sep=""),head=TRUE, sep=" "))
}
#plot
for(i in 1:3){
if(i==1){
plot(data.frame(data1[1], data1[2]), xlim=c(-0.2, -7), ylim=c(0.31, 0.35), yaxt="n", type="l", xlab="", ylab="",lty="solid", col="red2", lwd=4, axes=TRUE)
} else {
lines(data.frame(paste("data", i, "[1]", sep=""), paste("data", i, "[2]", sep="")) ,lty="twodash", col="deepskyblue4", lwd=4)
}
}
问题与“其他”之后的部分有关。数据没有绘制,我也没有收到任何错误信息。
感谢您的帮助,
答案 0 :(得分:5)
assign
几乎没有任何有意义的用途。使用列表可以更轻松地完成上述操作:
# Read the data by inserting each data.frame into our list.
data <- list()
for (i in 1:3) {
data[[i]] <- data.frame(runif(10), rnorm(10)) # Replace with your call to read.table.
}
# As we are lazy, we can pre-save our styles and just use them later
ltys <- c('solid', 'twodash', 'twodash')
cols <- c('red', 'deepskyblue4', 'deepskyblue4')
# Creating the empty plot first allows us to do everything else with lines. Note that there are a ton of different ways to archive this.
plot(NA, xlim=c(0,1), ylim=c(-2,2))
# And now we just may access the data by using the lists.
for (i in 1:length(data)) {
d <- data[[i]]
lines(d[,1], d[,2], lty=ltys[i], col=cols[i], lwd=4)
}
如果我们的目标是优雅,我们甚至可以采用完全不同的方法:
# This time we will read all data into one data.frame.
# This requires the data to be of the same form, however.
data <- data.frame()
for (i in 1:3) {
d <- data.frame(x=runif(10), y=rnorm(10))
# Here is the trick: We add the index i (or a file name, or something totally different) as a separate column.
data <- rbind(data, cbind(d, group=i))
}
# This is just to ensure that our group column is a factor.
data$group <- as.factor(data$group)
# Now, plotting could be done by various ways. Personally, I like the elegance of ggplot2.
library(ggplot2)
qplot(x,y,data=data, col=group, geom="line")
答案 1 :(得分:2)
这是因为您实际上只使用data1
。
第一个循环可以扩展为
data1 = read.table('data1_lambda.dat', ...)
data2 = read.table('data2_lambda.dat', ...)
data3 = read.table('data3_lambda.dat', ...)
而你的第二个循环是有点马车和故障的原因。 如果我扩展循环,会发生什么:
plot(data.frame(data1[1], data1[2]), ...)
lines(data.frame('data2[1]', 'data2[2]', ...)
lines(data.frame('data3[1]', 'data3[2]', ...)
即。您认为提取data2
和data3
,您实际上只使用字符串'data2'
和'data3'
(请注意引号)。
如果没有假设太多的数据并重构整个代码,这应该可以解决问题(对于第二个循环)。由于您只有三个数据文件,因此循环似乎与它们引入的问题相比有点广泛。
plot(data.frame(data1[1], data1[2]), xlim=c(-0.2, -7), ylim=c(0.31, 0.35), yaxt="n", type="l", xlab="", ylab="",lty="solid", col="red2", lwd=4, axes=TRUE)
lines(data.frame(data2[1], data2[2]) ,lty="twodash", col="deepskyblue4", lwd=4)
lines(data.frame(data3[1], data3[2]) ,lty="twodash", col="deepskyblue4", lwd=4)
如果你坚持循环,我们可以这样做:
for(i in 1:3){
if(i==1){
plot(data.frame(data1[1], data1[2]), xlim=c(-0.2, -7), ylim=c(0.31, 0.35), yaxt="n", type="l", xlab="", ylab="",lty="solid", col="red2", lwd=4, axes=TRUE)
} else {
dat <- get(paste('data', i, sep=''))
lines(data.frame(dat[1], dat[2]) ,lty="twodash", col="deepskyblue4", lwd=4)
}
}
要进一步评论您的代码,在read.table
来电中,您有两个嵌套的paste
来电,在这种情况下是不必要的。
粘贴(粘贴(“data”,i,sep =“”),“_ lambda.dat”,sep =“”) #可以完成 粘贴(粘贴(“data”,i,“_ lambda.dat”,sep =“”)