如果你有一个 txt 文件,你可以使用命令 textscan(...) 将文件 txt 导入到一个单元格中:
cell = textscan(fopen('file.txt'), 'options');
'cell' 是单元格,'file.txt' 是 txt 文件名。 'options' 是一个字符串,用于定义导入格式('%s' 导入字符串,'%f' 导入浮动,...)和分隔符的类型。以这种方式导入的所有数据都存储在单元格中,要加入单元格的第 n 个元素,您必须使用方括号 {}(例如 cell{1} 加入第一个元素)。
如果 'file.txt' 包含以下值:
1.2 2.3
3.4 4.5
使用以下代码
cell = textscan(fopen('file.txt'), '%f');
var = cell{1};
在变量“var”中存储了数字,但它是列向量而不是矩阵/表,必须重新排序:var = [1.2; 2.3; 3.4; 4.5]。
使用以下代码(它有点复杂,但不需要事先了解表格维度来重新排序数据):
cell = textscan(fopen('file.txt'), '%s', 'delimiter', '\n');
var = cell{1};
'var' 是一个元胞数组,每个元素包含字符串格式的文档行(由于分隔符)(var{1} = '1.2 2.3', var{2} = '3.4 4.5') .如果 N 是 'var' 的长度,使用从 1 到 N 的 for 循环,您可以加入各种字符串,将它们转换并以这种方式存储在矩阵中:
M = length(strread(var{1}, '%f')); %column number
N = length(var); %row number
a = zeros(N,M); %inizialization
for n = 1:N
a(n,:) = strread(var{n}, '%f');
end*
现在'a'是一个带有数字的矩阵:a = [1.2, 2.3; 3.4, 4.5] 用于分析和绘图。