0

我编写了一个 for 循环,在其中沿着它们所在的每一列相应地拆分 5000 行。

包含这些行的元胞数组示例: 在此处输入图像描述

从那张图片中,我想从第一列到最后,沿着该行各自的列相应地拆分每一行。

这是我写的代码:

for i = pdbindex(:,1)

    clean_pdb = regexprep(pdbindex, ':', ' '); % removes the colon (:) from the array and replaces it with a whitespace
    pdb2char = char(clean_pdb); % converts the cell array into a character array
    pdb2split = strsplit(pdb2char, ' '); % does a split based on the character array followed by a delimiter, which is the white space

end

我使用正则表达式将冒号 (:) 替换为空格。但是,它给我一个错误说明Input strings must have one row.。我不知道如何解决这个问题。

请指教。

4

1 回答 1

2

我会这样做:

%Some sample data
data = {'1 : 2  :  3 :4: 5: 6';'7 :8 : 9: 10 :11 :12'};

根据分隔符划分所有行(分隔符是空格和“:”的任意组合)

splitData = regexp(data,'[\s\:]*','split')

现在您的拆分数据可以读取为

example = splitData{row}{column};

您很可能希望将其转换为数字(而不是字符串)。您可以一次执行此操作,如下所示:

numericRow = num2double(splitData{rowNumber});
于 2012-02-20T19:49:16.593 回答