Main Content

本页的翻译已过时。点击此处可查看最新英文版本。

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)

Figure contains an axes. The axes contains an object of type image.

输出 Auint8 类,因为辅助函数 imreadcolormapalpha 返回空结果。

使用文本编辑器创建一个带有列标题的称为 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 预计会查找矩形格式(即像矩阵一样)的数值数据。文本标题可显示在数值数据的上方或左侧,如下所示:

  • 文件顶部的列标题或文件说明文本,位于数值数据上方。

  • 数值数据左侧的行标题。

示例: 'myFile.jpg'

数据类型: char | string

列分隔符,指定为字符向量或字符串标量。默认字符根据文件进行解释。对选项卡使用 '\t'

示例: ','

示例: ' '

数据类型: char | string

ASCII 文件中的文本标题行数,指定为非负整数标量。如果您不指定 headerlinesInimportdata 函数将会在文件中检测该值。

数据类型: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64

输出参数

全部折叠

文件中的数据,以矩阵、多维数组或标量结构体数组形式返回,具体取决于文件的特征。根据输入文件的文件格式,importdata 会调用辅助函数来读取数据。当辅助函数返回多个非空输出时,importdata 会将这些输出组合成一个 struct 数组。

下表列出了与可返回多个输出的辅助函数关联的文件格式,以及结构体数组 A 中的可能字段。

文件格式可能的字段

MAT 文件

每个字段对应一个变量

与每个变量关联。

ASCII 文件和电子表格

data
textdata
colheaders
rowheaders

对于 ASCII 文件,data 包含一个 double 数组。其他字段包含字符向量 cell 数组。textdata 包含行标题和列标题。
对于电子表格,每个字段包含一个 struct,并且每个字段对应一个工作表。

图像

cdata
colormap
alpha

请参阅 imread

音频文件

data
fs

请参阅 audioread

用于支持的大多数其他文件格式的 MATLAB 辅助函数返回一个输出。有关每个输出的类的详细信息,请参阅支持的导入和导出文件格式中列出的函数。

如果 ASCII 文件或电子表格包含列标题或行标题(但不同时包含这两种标题),importdata 会在输出结构体中返回 colheadersrowheaders,其中:

  • colheaders 仅包含最后一行列标题文本。importdata 将所有文本都存储在 textdata 字段中。

  • 仅当该文件或工作表包含单列行标题时,才会创建 rowheaders

在输入 ASCII 文件中检测到的列分隔符,以字符向量形式返回。

在输入 ASCII 文件中检测到的文本标题行数,以整数形式返回。

提示

  • 要导入非数值字符(包括字符数据列或者格式化的日期或时间)位于列标题或行标题之外的 ASCII 文件,请使用 textscan 而不是 importdata

在 R2006a 之前推出