数据导出(或输出)在 MATLAB 的意思是写入文件。MATLAB 允许您在另一个读取 ASCII 文件的应用程序中使用您的数据。为此,MATLAB 提供了几个数据导出选项。
您可以创建以下类型的文件-
数组中的矩形、分隔的ASCII数据文件。
击键的日记(或日志)文件和结果文本输出。
使用底层函数(如fprintf)的专用ASCII文件。
MEX文件,用于访问以特定文本文件格式写入的C / C ++或Fortran例程。
除此之外,您还可以将数据导出到电子表格。
有两种方法可以将数字数组导出为定界的ASCII数据文件-
使用save函数并指定-ascii限定符
使用dlmwrite函数
使用save函数的语法是-
save my_data.out num_array -ascii
其中,my_data.out是创建的带分隔符的ASCII数据文件,num_array是数字数组,并且 −ascii是说明符。
使用dlmwrite函数的语法是-
dlmwrite('my_data.out', num_array, 'dlm_char')
其中,my_data.out是创建的带分隔符的ASCII数据文件,num_array是数字数组, dlm_char是分隔符。
下面的示例演示了该概念。创建一个脚本文件并输入以下代码-
num_array = [ 1 2 3 4 ; 4 5 6 7; 7 8 9 0]; save array_data1.out num_array -ascii; type array_data1.out dlmwrite('array_data2.out', num_array, ' '); type array_data2.out
运行文件时,它显示以下结果-
1.0000000e+00 2.0000000e+00 3.0000000e+00 4.0000000e+00 4.0000000e+00 5.0000000e+00 6.0000000e+00 7.0000000e+00 7.0000000e+00 8.0000000e+00 9.0000000e+00 0.0000000e+00 1 2 3 4 4 5 6 7 7 8 9 0
请注意,save -ascii命令和dlmwrite函数不适用于作为输入的单元格数组。要从单元格数组的内容创建定界的ASCII文件,您可以
使用cell2mat函数将单元格数组转换为矩阵
或使用底层文件I / O功能导出单元数组。
如果使用save函数将字符数组写入ASCII文件,则它将等效于字符的ASCII写入文件。
例如,让我们将单词“ hello”写到文件中-
h = 'hello'; savetextdata.outh -ascii type textdata.out
MATLAB执行以上语句并显示以下结果。这是8位ASCII格式的字符串“ hello”的字符。
1.0400000e+02 1.0100000e+02 1.0800000e+02 1.0800000e+02 1.1100000e+02
日记文件是您的MATLAB会话的活动日志。日记功能可以在磁盘文件中创建会话的精确副本,但不包括图形。
要打开日记函数,请输入-
diary
(可选)您可以提供日志文件的名称,例如-
diary logdata.out
关闭日记函数-
diary off
您可以在文本编辑器中打开日记文件。
到目前为止,我们已经导出了数字数组。但是,您可能需要创建其他文本文件,包括数字和字符数据的组合,非矩形输出文件或具有非ASCII编码方案的文件。为此,MATLAB提供了底层fprintf函数。
与在底层I / O文件活动中一样,在导出之前,您需要使用fopen函数打开或创建文件并获取文件标识符。默认情况下,fopen打开文件以进行只读访问。您应指定写入或追加的权限,例如“ w”或“ a”。
处理完文件后,需要使用fclose(fid)函数将其关闭。
以下示例演示了概念-
创建一个脚本文件并在其中键入以下代码-
%创建一个包含两行的矩阵y x = 0:10:100; y = [x; log(x)]; %打开文件进行写入 fid = fopen('logtable.txt', 'w'); %表格标题 fprintf(fid, 'Log Function\n\n'); %按列顺序打印值 %文件的每一行上显示两个值 fprintf(fid, '%f %f\n', y); fclose(fid); %显示创建的文件 type logtable.txt
运行文件时,它显示以下结果-
Log Function 0.000000 -Inf 10.000000 2.302585 20.000000 2.995732 30.000000 3.401197 40.000000 3.688879 50.000000 3.912023 60.000000 4.094345 70.000000 4.248495 80.000000 4.382027 90.000000 4.499810 100.000000 4.605170