MATLAB数据导入
MATLAB数据导入
在编写一个程序时,经常需要从外部读入数据。MATLAB使用多种格式打开数据。本章将要介绍MATLAB中数据的导入。
MATLAB中导入数据的方式有两种,分别是在命令行通过代码把数据导进去和通过MATLAB的数据导入向导导入数据。本节将为大家介绍第一种数据导入方法。
MATLAB中导入数据意味着从外部文件加载数据。importdata 函数允许加载各种数据的不同格式的文件。它具有以下五种形式:
S.N. | 函数&说明 |
---|---|
1 |
A = importdata(filename) 将数据从文件名所表示的文件中加载到数组 A 中。 |
2 |
A = importdata('-pastespecial') 从系统剪贴板加载数据,而不是从文件加载数据。 |
3 |
A = importdata(___, delimiterIn) 将 delimiterIn 解释为 ASCII 文件、文件名或剪贴板数据中的列分隔符。可以将 delimiterIn 与上述语法中的任何输入参数一起使用。 |
4 |
A = importdata(___, delimiterIn, headerlinesIn) 从 ASCII 文件、文件名或剪贴板加载数据,并从 lineheaderlinesIn+1 开始读取数字数据。 |
5 |
[A, delimiterOut, headerlinesOut] = importdata(___) 在分隔符输出中返回检测到的分隔符字符,并使用前面语法中的任何输入参数检测headerlinesOut 中检测到的标题行数。 |
默认情况下,Octave 没有importdata() 函数的支持,所以要搜索并安装这个包下面的例子Octave 安装工作。
示例 1
该例中我们将加载和显示图像文件。
在MATLAB中建立一个脚本文件,并输入下述代码:
filename = 'smile.jpg'; A = importdata(filename); image(A);
运行该文件,MATLAB显示出图像文件。
注意:该图像文件必须保存在当前目录。
示例 2
本例中,我们在MATLAB中导入文本文件,并指定分隔符和列标题。
我们建立以空格分隔的 ASCII 文件的列标题,文件名为 weeklydata.txt。
文本文件 weeklydata.txt 内容如下:
SunDay MonDay TuesDay WednesDay ThursDay FriDay SatureDay 95.01 76.21 61.54 40.57 55.79 70.28 81.53 73.11 45.65 79.19 93.55 75.29 69.87 74.68 60.68 41.85 92.18 91.69 81.32 90.38 74.51 48.60 82.14 73.82 41.03 0.99 67.22 93.18 89.13 44.47 57.63 89.36 13.89 19.88 46.60
在MATLAB中建立一个脚本文件,并输入下述代码:
filename = 'weeklydata.txt'; delimiterIn = ' '; headerlinesIn = 1; A = importdata(filename,delimiterIn,headerlinesIn); % View data for k = [1:7]disp(A.colheaders{1, k})disp(A.data(:, k))disp(' ') end
运行该文件,显示以下结果:
SunDay95.010073.110060.680048.600089.1300MonDay76.210045.650041.850082.140044.4700TuesDay61.540079.190092.180073.820057.6300WednesDay40.570093.550091.690041.030089.3600ThursDay55.790075.290081.32000.990013.8900FriDay70.280069.870090.380067.220019.8800SatureDay81.530074.680074.510093.180046.6000
示例 3
本例讲的是如何从剪贴板导入数据到MATLAB。
复制到剪贴板中的以下几行:
Mathematics is simple
在MATLAB中建立一个脚本文件,并输入下述代码:
A = importdata('-pastespecial')
运行该文件,显示以下结果:
A = 'Mathematics is simple'
MATLAB低级别的文件I / O
MATLAB 中 importdata 函数是一个高层次的函数。如果要处理低级别的文件,在MATLAB中的 I / O 功能允许读取或写入数据到一个文件中的大部分控制权。但是,使用这些功能的要求是这些文件需要具有更加详细的信息,这样能够提高工作效率。
MATLAB字节或字符的读取和写入操作提供了以下功能:
函数 | 描述 |
---|---|
fclose | 关闭一个或全部已打开的文件 |
feof | 测试文件结尾 |
ferror | 有关文件I / O错误的信息 |
fgetl | 从文件读取行, 删除换行符 |
fgets | 从文件读取行, 保留换行符 |
fopen | 打开文件, 或获取有关打开的文件的信息 |
fprintf | 将数据写入文本文件 |
fread | 从二进制文件读取数据 |
frewind | 将文件位置指示器移动到打开文件的开头 |
fscanf | 从文本文件读取数据 |
fseek | 移动到文件中的指定位置 |
ftell | 获得打开文件的位置 |
fwrite | 将数据写入二进制文件 |
MATLAB导入文本数据文件与低级别的I/O
MATLAB 低层次的导入文本数据文件由以下函数实现:
fscanf 函数读取文本或 ASCII 文件格式的数据。
fgetl 函数和 fgets 函数读取一行的文件,换行符分隔每一行。
fread 函数读出的数据流的字节或位的级别。
具体例子
我们有 myfile.txt 文本数据文件保存在我们的工作目录。该文件存储3个月的降雨量数据,分别是2012年的6月,7月和8月。
myfile.txt 包含重复的数据集的时间,一个月的雨量测量五个数据项。头数据存储数个月的中号,所以我们有M组测量。
该文件内容如下:
Rainfall Data Months: June, July, AugustM=3 12:00:00 June-2012 17.21 28.52 39.78 16.55 23.67 19.15 0.35 17.57 NaN 12.01 17.92 28.49 17.40 17.06 11.09 9.59 9.33 NaN 0.31 0.23 10.46 13.17 NaN 14.89 19.33 20.97 19.50 17.65 14.45 14.00 18.23 10.34 17.95 16.46 19.34 09:10:02 July-2012 12.76 16.94 14.38 11.86 16.89 20.46 23.17 NaN 24.89 19.33 30.97 49.50 47.65 24.45 34.00 18.23 30.34 27.95 16.46 19.34 30.46 33.17 NaN 34.89 29.33 30.97 49.50 47.65 24.45 34.00 28.67 30.34 27.95 36.46 29.34 15:03:40 August-2012 17.09 16.55 19.59 17.25 19.22 17.54 11.45 13.48 22.55 24.01 NaN 21.19 25.85 25.05 27.21 26.79 24.98 12.23 16.99 18.67 17.54 11.45 13.48 22.55 24.01 NaN 21.19 25.85 25.05 27.21 26.79 24.98 12.23 16.99 18.67
我们将数据导入此文件,并显示这些数据。步骤如下:
使用 fopen 函数打开文件并获得文件标识符。
描述文件中的数据格式说明符,如 '%s' 为一个字符串,'%d' 为一个整数,或 '%f' 表示一个浮点数。
要跳过文字字符的文件,包括他们的格式描述。要跳过一个数据字段,在符使用一个星号(“*”)。
例如,要读取头,并返回单个的M值,我们这样写:
M = fscanf(fid, '%*s %*s %*s %*s %*s %*s M=%d', 1);
缺省情况下,fscanf读取数据,直到它可以根据我们的格式说明描述的数据不匹配,或它到达文件末尾的。在这里,我们将使用for循环阅读3组数据,每一次,它会读取7行5列。
我们将创建一个名为 mydata 在工作区中,从文件中读取数据存储结构。这种结构具有三个字段:时间、月和 raindata 阵列。
在MATLAB中建立一个脚本文件,并输入下述代码:
filename = '/data/myfile.txt'; rows = 7; cols = 5;% open the file fid = fopen(filename);% read the file headers, find M (number of months) M = fscanf(fid, '%*s %*s %*s %*s %*s %*s M=%d', 1);% read each set of measurements for n = 1:Mmydata(n).time = fscanf(fid, '%s', 1);mydata(n).month = fscanf(fid, '%s', 1);% fscanf fills the array in column order,% so transpose the resultsmydata(n).raindata = ...fscanf(fid, '%f', [rows, cols]); end for n = 1:Mdisp(mydata(n).time), disp(mydata(n).month)disp(mydata(n).raindata) end% close the file fclose(fid);
运行该文件,显示以下结果:
12:00:00 June-201217.2100 17.5700 11.0900 13.1700 14.450028.5200 NaN 9.5900 NaN 14.000039.7800 12.0100 9.3300 14.8900 18.230016.5500 17.9200 NaN 19.3300 10.340023.6700 28.4900 0.3100 20.9700 17.950019.1500 17.4000 0.2300 19.5000 16.46000.3500 17.0600 10.4600 17.6500 19.340009:10:02 July-201212.7600 NaN 34.0000 33.1700 24.450016.9400 24.8900 18.2300 NaN 34.000014.3800 19.3300 30.3400 34.8900 28.670011.8600 30.9700 27.9500 29.3300 30.340016.8900 49.5000 16.4600 30.9700 27.950020.4600 47.6500 19.3400 49.5000 36.460023.1700 24.4500 30.4600 47.6500 29.340015:03:40 August-201217.0900 13.4800 27.2100 11.4500 25.050016.5500 22.5500 26.7900 13.4800 27.210019.5900 24.0100 24.9800 22.5500 26.790017.2500 NaN 12.2300 24.0100 24.980019.2200 21.1900 16.9900 NaN 12.230017.5400 25.8500 18.6700 21.1900 16.990011.4500 25.0500 17.5400 25.8500 18.6700
MATLAB数据导入相关推荐
- 2021-02-23 Matlab数据导入--importdata和load函数
Matlab数据导入--importdata和load函数 importdata和load函数 1.引言 在使用matlab将数据导入到工作空间的时候,经常会使用到两个函数,一个是importdata ...
- matlab数组 xp,windowsxp系统将matlab数据导入excel的方法
matlab是一款非常强大的商业数学软件,不仅能够读取Excel表格中的数据,还支持将matlab中的变量导入到Excel表格中.接下来,系统城小编就为大家分享windowsxp系统将matlab数据 ...
- 导出matlab程序,Matlab数据导入导出
Matlab提供了从磁盘文件或剪贴簿转载数据至工作区(数据导入)和将工作区变量存入磁盘文件(数据导出)的多种途径. 最简单的办法是使用界面导入向导,打开文件菜单中的导入数据而后按提示操作. 一.导入文 ...
- simulink自定义信号源方法matlab数据导入sim
simulink自定义信号源 方法: https://jingyan.baidu.com/article/e6c8503c7abdb2e54f1a18a0.html https://jingyan.b ...
- 【Simulink教程案例17】基于simulink的伪码序列相关峰检测仿真——将matlab数据导入到Simulink中作为信号源
欢迎订阅<FPGA/MATLAB/SIMULINK系列教程> Simulink教程目录 本课程学习成果预览: 目录 1.软件版本 2.伪码序列相关峰理论简介
- adams数据导出matlab,adams数据导入matlab
Matlab 数据导入方法在编写一个程序时,经常需要从外部读入数据,或者将程序运行的结果保存为文 件.MATLAB 使用多种格式打开和保存数据.本章将要介绍 MATLAB 中文件...... adam ...
- matlab在曲线给命名,matlab 利用xlsread画图,怎么将一组excel数据导入,通过matlab作图...
Matlab 循环 for 语句 xlsread EXCEL表格数据导入 画图 Matlab的 xlsread() 函数可以将Excel数据到matlab工作空间,然后就可以根据读入据作图.下面给出操 ...
- 如何将txt格式的数据导入到MATLAB中,并绘制图线
如何将txt格式的数据导入到MATLAB中,并绘制图线 1.把txt格式的文件复制到MATLAB的目录下,在txt文件上点击右键→Import Data→next→Finish, 在workspace ...
- 将C/C++程序的变量数据导入到MATLAB中的方法
2016-5-21日:我发现自己真是傻,既然对象是图像,那何必把像素值导出来呢?直接将图像输出,然后MATLAB再读入图像不就可以了? 这篇博文随接上一篇博文: 将MATLAB的变量数据导入到VC中的 ...
最新文章
- 2022-2028年中国工业节能行业深度调研及投资前景预测报告
- 单价数量和总价的公式_小学六年超全的数学公式!家长们赶紧给孩子看过来……...
- python排序的两个方法
- 边缘计算精华问答 | 火爆的边缘计算为何兴起?
- 第12课第2.2节 字符设备驱动程序之LED驱动程序_测试改进
- 原创 | 职场风云 (五)成长的烦恼
- 电力设计手册_10KV及以下供配电设计与安装图集
- 基于php014居民小区物业管理系统
- 正则表达式应用(以手机号为例)
- CART剪枝算法详解
- MMA7455加速度传感器測量角度
- 台式计算机有没有无线连接模块,台式机能不能连接wifi_台式机怎么连接wifi
- five86-2靶机渗透攻略
- HDU 1849 Rabbit and Grass
- pu是什么单位(pu革是什么材料)
- A Novel Proof-of-Reputation Consensus for Storage Allocation in Edge Blockchain Systems 精读笔记(三)
- 关于公正执法的一点想法
- jq html 回车提交表单,jQuery事件之键盘事件(ctrl+Enter回车键提交表单等)
- 倍分法DID详解(一):传统DID
- 联想万全服务器 R630 故障处理
热门文章
- 利用simhash来进行文本去重复
- Android Studio中如何将ijkplayer 0.6.3导入自己的项目中并使用
- 分别用雅可比(Jacobi)迭代法和高斯—塞德尔(Gauss—Seidel)迭代法求解线性方程组
- 路径中的“./“,“../“,“/“ 代表的含义
- Android开发之获取手机运行时间
- 数据结构与算法——赫夫曼树基本实现
- 静态库入门(VS2017win10)
- 51单片机点亮LED灯以及实现2盏LED灯的交替闪烁
- 谷歌测试工具_使用Google网站优化工具进行A / B测试的指南
- 建筑物防雷接地工程的分类和措施