Matlab中importdata函数的使用
目录
语法
说明
示例
导入并显示图像
导入文本文件并指定分隔符和列标题
导入文本文件并返回检测到的分隔符
从剪贴板导入数据
importdata函数的功能是从文件加载数据。
语法
A = importdata(filename)
A = importdata('-pastespecial')
A = importdata(___,delimiterIn)
A = importdata(___,delimiterIn,headerlinesIn)
[A,delimiterOut,headerlinesOut] = importdata(___)
说明
A = importdata(filename) 将数据加载到数组 A 中。
A = importdata('-pastespecial') 从系统剪贴板而不是文件加载数据。
A = importdata(___,delimiterIn) 将 delimiterIn 解释为 ASCII 文件 filename 或剪贴板数据中的列分隔符。可以将 delimiterIn 与以上语法中的任何输入参数结合使用。
A = importdata(___,delimiterIn,headerlinesIn) 从 ASCII 文件 filename 或剪贴板加载数据,并读取从第 headerlinesIn+1 行开始的数值数据。
[A,delimiterOut,headerlinesOut] = importdata(___) 使用先前语法中的任何输入参数,在 delimiterOut 中额外返回检测到的输入 ASCII 文件中的分隔符,以及在 headerlinesOut 中返回检测到的标题行数。
示例
导入并显示图像
导出并显示示例图像 ngc6543a.jpg。
A = importdata('ngc6543a.jpg');
image(A)
输出 A 为 uint8 类,因为辅助函数 imread 对 colormap 和 alpha 返回空结果。
导入文本文件并指定分隔符和列标题
使用文本编辑器创建一个带有列标题的称为 myfile01.txt 的空格分隔 ASCII 文件。
Day1 Day2 Day3 Day4 Day5 Day6 Day7
95.01 76.21 61.54 40.57 5.79 20.28 1.53
23.11 45.65 79.19 93.55 35.29 19.87 74.68
60.68 1.85 92.18 91.69 81.32 60.38 44.51
48.60 82.14 73.82 41.03 0.99 27.22 93.18
89.13 44.47 17.63 89.36 13.89 19.88 46.60
导入该文件并指定空格分隔符和单个列标题。
filename = 'myfile01.txt';
delimiterIn = ' ';
headerlinesIn = 1;
A = importdata(filename,delimiterIn,headerlinesIn);
查看第 3 列和第 5 列。
for k = [3, 5]
disp(A.colheaders{1, k})
disp(A.data(:, k))
disp(' ')
end
Day3
61.5400
79.1900
92.1800
73.8200
17.6300
Day5
5.7900
35.2900
81.3200
0.9900
13.8900
导入文本文件并返回检测到的分隔符
使用文本编辑器创建一个称为 myfile02.txt 的逗号分隔 ASCII 文件。
1,2,3
4,5,6
7,8,9
导入该文件并显示输出数据和检测到的分隔符。
filename = 'myfile02.txt';
[A,delimiterOut]=importdata(filename)
A =
1 2 3
4 5 6
7 8 9
delimiterOut =
,
从剪贴板导入数据
将以下行复制到剪贴板。选择相应文本,右键点击,然后选择复制。
1,2,3
4,5,6
7,8,9
键入以下内容将剪贴板数据导入到 MATLAB® 中。
A = importdata('-pastespecial')
A =
1 2 3
4 5 6
7 8 9
要导入的文件的名称和扩展名,指定为字符向量或字符串标量。如果 importdata 可识别文件扩展名,则会调用用于导入关联的文件格式的 MATLAB 辅助函数(如用于 MAT 文件的 load 或用于电子表格的 xlsread)。否则,importdata 会将文件解释为分隔的 ASCII 文件。
对于 ASCII 文件和电子表格,importdata 预计会查找矩形格式(即像矩阵一样)的数值数据。文本标题可显示在数值数据的上方或左侧,如下所示:
-
文件顶部的列标题或文件说明文本,位于数值数据上方。
-
数值数据左侧的行标题。
文件中的数据,以矩阵、多维数组或标量结构体数组形式返回,具体取决于文件的特征。根据输入文件的文件格式,importdata 会调用辅助函数来读取数据。当辅助函数返回多个非空输出时,importdata 会将这些输出组合成一个 struct 数组。
下表列出了与可返回多个输出的辅助函数关联的文件格式,以及结构体数组 A 中的可能字段。
文件格式 | 可能的字段 | 类 |
---|---|---|
MAT 文件 | 每个字段对应一个变量 | 与每个变量关联。 |
ASCII 文件和电子表格 | data | 对于 ASCII 文件,data 包含一个 double 数组。其他字段包含字符向量 cell 数组。textdata 包含行标题和列标题。 |
图像 | cdata | 可参考 imread函数。 |
音频文件 | data | 可参考audioread函数。 |
用于支持的大多数其他文件格式的 MATLAB 辅助函数返回一个输出。有关每个输出的类的详细信息,可以参考支持的导入和导出文件格式中列出的函数。
如果 ASCII 文件或电子表格包含列标题或行标题(但不同时包含这两种标题),importdata 会在输出结构体中返回 colheaders 或 rowheaders,其中:
-
colheaders 仅包含最后一行列标题文本。importdata 将所有文本都存储在 textdata 字段中。
-
仅当该文件或工作表包含单列行标题时,才会创建 rowheaders。
在输入 ASCII 文件中检测到的文本标题行数,以整数形式返回。
提示
-
要导入非数值字符(包括字符数据列或者格式化的日期或时间)位于列标题或行标题之外的 ASCII 文件,可以使用textscan 而不是 importdata。