繁体   English   中英

在简单的R脚本中收到“在1级没有这样的索引”错误

[英]Receiving “no such index at level 1” error in simple R script

当我运行以下R代码块时:

require(openair)
require(png)

topDir <- "C:/Users/djh/Desktop/WindRoses"
subdirs <- c("Abbotsford_Observations") #, "Vancouver_Observations", "Abbotsford_Modelled", "Vancouver_Modelled")
years <- c(1985) #, 1995, 2001, 2006)

for(i in 1:length(subdirs)){
  for(j in 1:length(years)){
    wd <- paste(topDir, subdirs[i], years[j], sep="/")
    files <- list.files(wd, pattern = "\\.out$")
    for(k in 1:length(files)){
      theData <- data.frame(read.table(paste(wd, files[k], sep="/"), header = TRUE, sep=""))
      u <- theData$U10
      v <- theData$V10

      theData["windSpd"] <- sqrt(u^2 + v^2)
      theData["windDir"] <- (270 - (atan2(u/theData$windSpd, v/theData$windSpd)*(180/pi)))

      nameSplit <- strsplit(files[k], ".")

      png(file=paste(wd, "/", nameSplit[[1]], ".png", sep = ""))
      windRose <- windRose(theData, theData$windSpd, theData$windDir, angle = 22.5)
      dev.off()
    }
  }
}

我收到错误:

在运行了整个代码之后,“。subset2(x,i,精确=精确)中的错误:级别1上没有这样的索引”

在堆栈交换上查看此错误的其他实例,似乎它可能与files[k]的字符串拆分有关,但没有任何答案可以解决我的问题。

注意:我试图在unlist上使用nameSplit ,但无法解决问题。

我尝试拆分的字符串的示例是:

wrfout_d04_1985-07-16.ts.abbotsford.out

这肯定是发生错误的地方,还是脚本中其他地方的明显原因?

我认为在用于拆分文件名的正则表达式定义中,点应该用双反斜杠屏蔽,因为在files变量分配所在的行中已完成。 另外,如果之后要使用nameSplit[1]选择拆分字符串的第一部分,则unlist()命令可能会很有用。

因此,我建议您使用

nameSplit <- unlist(strsplit(files[k], "\\."))

并查看问题是否仍然存在。

希望这可以帮助。

问题实际上出在不同的地方。 openair软件包中的windRose命令要求在下一行中输入风速和风向,而不是在原始问题中如何显示风速和风向。

wind_rose <- windRose(theData, ws="windSpd", wd="windDir", angle = 22.5)

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM