0

几天来我一直在徒劳地尝试做一件看似简单的事情——我想从一个看起来像这样的 .txt 文件中读取数据:

    0.221351321
    0.151351321
    0.235165165
    8.2254546 E-7

进入matlab。我已经能够使用 fscanf 命令将 .txt 文件中的数据作为列向量加载,如下所示:

    U=fscanf(FileID, '%e')

前提是我先浏览文件并删除数据集中出现科学记数法的“E”之前的空格。

由于我必须生成大量这样的集合,因此必须对每个 .txt 文件进行搜索和替换是不切实际的。

有没有办法让 matlab 读取出现的数据,如上面的示例(在“E”之前有空格),并将其放入列向量中?

对于任何了解 PARI-GP 的人来说,另一种解决方法是首先让输出中没有空格——但到目前为止,我还没有找到一种方法来以科学记数法擦除“E”之前的空格,而我无法预测科学计数法中的数字是否会出现在数据集中。

谢谢!

4

3 回答 3

1

谢谢大家的帮助,我找到了解决办法。有一种方法可以消除 PARI-GP 中的空格,以便输出的 .txt 文件以没有空格开头。我将输出设置为“prettymatrix”。需要输入以下内容:

    ? \o{0}

将输出更改为“Raw”,以消除科学记数法中“E”之前的空格。

再次感谢你的帮助。

于 2017-06-17T19:50:44.980 回答
0

一个班轮:

data = str2double(strsplit(strrep(fileread('filename.txt'),' ',''), '\n'));

strrep删除所有空格,strsplit将每一行作为单独的字符串,并将str2double字符串转换为数字。

于 2017-06-15T08:43:56.613 回答
0

一个简单的方法,可能不是最好的,是逐行读取,删除空格并转换回浮点数。

例如,

x = []
tline = fgetl(FileID);
while ischar(tline)
    x = [x str2num(tline(find(~isspace(tline))))]
    tline = fgetl(FileID);
end
于 2017-06-15T01:28:08.963 回答