1

我的问题是缩短重复过程。

Data1=dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t',[31 1 286 255]);

Data2=dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t',[299 1 554 255]);

Data3=dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t',[567 1 822 255]);

Data4=dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t',[835 1 1090 255]);

Data5=dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t',[1103 1 1358 255]);

Data6=dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t',[1371 1 1626 255]);

Data7=dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t',[1639 1 1894 255]);

Data8=dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t',[1907 1 2162 255]);

Data9=dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t',[2175 1 2430 255]);

Data10=dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t',[2443 1 2698 255]);

Data11=dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t',[2711 1 2966 255]);

Data12=dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t',[2979 1 3234 255]);

Data13=dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t',[3247 1 3502 255]);

其中前 30 行必须在获取 Data1 之前跳过。在 Data1 之后,必须忽略 Data2 - Data13 的 12 行。每个数据包含 256*255 矩阵。

注意:dlmread('myfile.txt', '\t', [R1 C1 R2 C2]);

对于您的所有帮助,我将不胜感激。谢谢你。

4

1 回答 1

5

您可以使用循环并在单元格数组中收集数据集,例如(未测试)

nData = 13;

data = cell(nData,1);

for n = 1:nData
    startPos = 31+(n-1)*268;
    endPos = 286 + (n-1)*268;

    data{n} = dlmread('BadgCk-20001103-RZhS-1hAccumx10-TextData0-1.txt','\t', [startPos 1 endPos 255]);
end

编辑:如果您想在之后将所有数据合并到一个大矩阵中,您可以使用

dataMatrix = [data{:}]

您可能需要首先转置 dlmread 的结果,具体取决于您希望如何连接到最终矩阵

于 2010-08-19T09:36:39.607 回答