我有一个与 R 相关的问题,这与必须读取许多文件并处理这些文件有关。每个文件用于在不同站点的不同时间进行的臭氧测量。数据采用表格格式,我可以使用以下方式读取数据:
files <- list.files()
data <- lapply(files, read.table, skip=19)
这为我现在要处理的所有文件提供了一个数据框。例如文件被命名为:
> head(files)
[1] "fiji_19980105.dat" "fiji_19980112.dat" "fiji_19980119.dat"
[4] "fiji_19980130.dat" "fiji_19980206.dat" "fiji_19980213.dat"
其中“fiji”为电台名称,日期为 YMD 格式。我想对数据框进行平均以获得该站的月平均值(我一次只需要在一个站上工作,所以我真的只想对称为数据的数据框进行平均以产生 12 组平均数据)。
我想我可以使用一些 ?apply 函数来做到这一点,但我真的不知道如何做到这一点。任何关于解决方案的建议都非常感谢!
作为将日期添加到数据框中的结果示例,我们有:
> head(dat)
V1 V2 V3 V4 V5 V6 V7 V8 V9 V10 Date
1 9000 1007.7 0.006 29.6 74 0.59 0.006 9000 9000 9000 1998-01-05
2 9000 1005.2 0.028 29.3 75 0.62 0.006 9000 9000 9000 1998-01-05
3 9000 1001.6 0.060 28.5 78 0.63 0.006 9000 9000 9000 1998-01-05
> str(dat)
'data.frame': 153994 obs. of 11 variables:
$ V1 : int 9000 9000 9000 9000 9000 9000 9000 9000 9000 9000 ...
$ V2 : num 1008 1005 1002 997 993 ...
$ V3 : num 0.006 0.028 0.06 0.104 0.14 0.169 0.198 0.238 0.271 0.301 ...
$ V4 : num 29.6 29.3 28.5 27.9 27.6 27.2 27 26.6 26.2 26 ...
$ V5 : int 74 75 78 79 80 81 82 84 85 85 ...
$ V6 : num 0.59 0.62 0.63 0.68 0.69 0.7 0.72 0.74 0.75 0.76 ...
$ V7 : num 0.006 0.006 0.006 0.007 0.007 0.007 0.007 0.008 0.008 0.008 ...
$ V8 : num 9000 9000 9000 9000 9000 9000 9000 9000 9000 9000 ...
$ V9 : num 9000 9000 9000 9000 9000 9000 9000 9000 9000 9000 ...
$ V10 : num 9000 9000 9000 9000 9000 9000 9000 9000 9000 9000 ...
$ Date: Date, format: "1998-01-05" "1998-01-05" ...