3

我有以下栅格并希望将它们导入 R。我的文件现在称为:

B02_10m.jp2
B03_10m.jp2
B04_10m.jp2
B08_10m.jp2

B05_20m.jp2
B06_20m.jp2
B07_20m.jp2
B8A_20m.jp2
B11_20m.jp2
B12_20m.jp2

它们位于不同的子文件夹中。这就是我正在使用的方式recursive=TRUE

我尝试使用以下选项来组合条件,但它不起作用。

 S2 <- "my/path"
S2 <- list.files(S2, recursive = TRUE, full.names = TRUE, pattern =  "B0[2348]_10m.jp2$ | B(0[567]_20m)|(1[12]_20m)|(8A_20m).jp2$")

S2 <- "my/path"
S2 <- list.files(S2, recursive = TRUE, full.names = TRUE, pattern =  "B0[2348]_10m | B(0[567]_20m)|(1[12]_20m)|(8A_20m).jp2$")
4

1 回答 1

4

对于其他用户并基于@docendo discimus 回答,这里是在我的情况下列出文件时结合不同条件的想法。我的条件基于字母 B 后面的数字,因此:

pattern="B( here we need to write the conditions).jp2$

首先,我们将设置导入文件 B02_10m、B03_10m、B04_10m、B08_10m 的条件

patter="B(FIRST CONDITION OR SECOND CONDITION).jp2$
pattern="B((0[2348]_10m)|SECOND CONDITION).jp2$

其次,我们将导入文件 B05_20m、B06_20m、B07_20m、B8A_20m、B11_20m、B12_20m。在这种情况下,我们必须结合几个子条件,因为模式从例如:02 变为 11、12 和 8A

首先我们编写 5、6 和 7 的代码

pattern="B((0[2348]_10m)|((0[567])_20m)).jp2$

然后我们添加波段 11 和 12 的代码

pattern="B((0[2348]_10m)|((0[567])|(1[12])_20m)).jp2$

然后,8A的代码

pattern="B((0[2348]_10m)|(((0[567])|(1[12])|(8A))_20m)).jp2$

希望清楚

于 2017-12-07T12:44:40.717 回答