0

大家好,我正在尝试制作一个循环文件​​来读取多个文件,这是我到目前为止所做的:

anoini = 1980;
anofin = 1981;

mesini = 1;
mesfin = 1;

diai=1;
diaf=1;

nano = (anofin-anoini)+1;


if (mesini == 1) || (mesini == 3) || (mesini == 5) || (mesini == 7) || (mesini == 8) || (mesini == 10) || (mesini == 12)
    lmes = 31;
elseif (mesini == 4) || (mesini == 6) || (mesini == 9) || (mesini == 11)
    lmes = 30;
elseif (mesini == 2)
    lmes = 28;
end


for idia=1:lmes
    for iano = anoini:anofin
        for nn = 1:nano


     D_1{nn,idia} = load(sprintf('F:\\salidas_nam\\%d\\%d%0.2u%0.2u06_NAM_day01.dat',iano,iano,mesini,idia));

        end
    end
end

例如我想要这两个文件,但它似乎只读取一个

"F:\salidas_nam\1980\1980010106_NAM_day01.dat"
"F:\salidas_nam\1981\1981010106_NAM_day01.dat"

这个想法是自动化这个,所以我可以选择阅读哪些年份,没有必要使用sprintf,如果有人知道如何以另一种方式做到这一点,我会欣赏它。

4

1 回答 1

0

我认为问题出在您的内部循环中。您正在迭代nn但没有在文件名的构造中使用它。所以你最终加载了每个文件两次:

因此,您的输出看起来像这样(重复文件):

D_1{1,1} = F:\salidas_nam\1980\1980010106_NAM_day01.dat
D_1{2,1} = F:\salidas_nam\1980\1980010106_NAM_day01.dat
D_1{1,2} = F:\salidas_nam\1981\1981010106_NAM_day01.dat
D_1{2,2} = F:\salidas_nam\1981\1981010106_NAM_day01.dat
...

但是,我认为您想要这个(不重复):

D_1{1,1} = F:\salidas_nam\1980\1980010106_NAM_day01.dat
D_1{2,1} = F:\salidas_nam\1981\1981010106_NAM_day01.dat
D_1{1,2} = F:\salidas_nam\1980\1980010206_NAM_day01.dat
D_1{2,2} = F:\salidas_nam\1981\1981010206_NAM_day01.dat
...

如果是这种情况,那么您可以删除内部for循环并执行以下操作:

for idia=1:lmes
    nn = 1;
    for iano = anoini:anofin
        D_1{nn,idia} = load(sprintf('F:\\salidas_nam\\%d\\%d%0.2u%0.2u06_NAM_day01.dat',iano,iano,mesini,idia));
        nn = nn+1;
    end
end

正如 Adriaan 在评论中提到的那样,这并没有解决您可能遇到的潜在闰年问题。

于 2018-10-04T14:17:12.773 回答