您必须以文本形式读取数据(textscan、textread、dlmread、etc.)并转换为数字。
假设您已将数据读入一个单元格数组,每个单元格中有一个数字:
>> C = {'1,2345','3,14159','2,7183','1,4142','0,7071'}
C =
'1,2345' '3,14159' '2,7183' '1,4142' '0,7071'
如下使用strrep和str2double:
>> x = str2double(strrep(C,',','.'))
x =
1.2345 3.1416 2.7183 1.4142 0.7071
对于来自 cmets 的示例数据,您有一个文件“1.dat”,其格式类似于:
1,2 3,4
5,6 7,8
这里有一个空格作为分隔符。默认情况下,textscan 使用空格作为分隔符,这很好。您需要在下面更改的是数据中列数的格式说明符,方法是为每列重复 %s(例如,这里我们需要两列 '%s%s'):
>> fid = fopen('1.dat','r');
>> C = textscan(fid,'%s%s')
C =
{2x1 cell} {2x1 cell}
>> fclose(fid);
textscan 的输出是由空格分隔的每一列的元胞数组。将列组合成单个元胞数组并运行命令以转换为数字:
>> C = [C{:}]
C =
'1,2' '3,4'
'5,6' '7,8'
>> x = str2double(strrep(C,',','.'))
x =
1.2000 3.4000
5.6000 7.8000