matlab怎么选取excel的特定列构成数组
例如:
要将A、C、D、E四列组成一个数组,即除去B列。
首先看matlab读取excel专用函数xlsread是否提供了相应的功能。
num = xlsread(filename)
读取名为filename文件的数据,默认读取sheet1中的数据。filename要包括文件路径。
num = xlsread(filename,sheet)
读取名为filename文件工作表sheet中的的数据,
num = xlsread(filename,xlRange)
读取名为filename文件的数据,默认读取sheet1中的数据,读取xlRange列的
num = xlsread(filename,sheet,xlRange)
读取名为filename文件工作表sheet,xlRange列中的的数据
num = xlsread(filename,sheet,xlRange,'basic')
用基本的形式读取电子表格中的数据,the default on systems without Excel for Windows.(不知道怎么翻译?难道是说不支持windows下的excel?),如果没有工作表和列的特别要求,默认为空字符。例如: num= xlsread(filename,'','','basic').
不过我在matlab下运行的num= xlsread('D:\program files\matlab\example.xls','','','basic')报错,我的是windows系统
[num,txt,raw]= xlsread(filename)
num返回filename中的数据部分数组,txt部分用NaN表示
txt返回filename的txt值
raw返回和原数组相同大小的元胞数组
Example:
[num,txt,raw]= xlsread('D:\program files\matlab\example.xls')
>> example
num =
1 2 2 3
5 6 6 7
3 9 8 14
NaN NaN NaN 5
txt =
'yx' 's' 'a'
raw =
[ 1] [2] [2] [ 3]
[ 5] [6] [6] [ 7]
[ 3] [9] [8] [14]
'yx' 's' 'a' [ 5]
___ = xlsread(filename,-1)
交互式的打开一个windows下的excel窗口读取excel中的数据
Example:
num= xlsread('D:\program files\matlab\example.xls',-1)
先在打开的excel中选取数据,再返回matlab点击弹出窗口中的确定(如上图)即可。不过好像也不支持隔列选取,只支持多列连续选取
[num,txt,raw,custom]= xlsread(filename,sheet,xlRange,'',functionHandle)
执行一个函数,返回多种类型的矩阵
Example:
- 在工作表中执行一个函数 然后返回数值型数据
- 在命令行中输入以下命令 产生一个随机的正态分布矩阵(gallery函数用法参照help)
misc = pi*gallery('normaldata',[10,3],1);
xlswrite('myExample.xlsx',misc,'MyData');
- 编写特定功能的函数(此处是将[-3 3]以外的数据变成-3或3,按照最近原则)
function [Data] = setMinMax(Data)
minval = -3; maxval = 3;
for k = 1:Data.Count
v = Data.Value{k};
if v > maxval || v < minval
if v > maxval
Data.Value{k} = maxval;
else
Data.Value{k} = minval;
end
end
end
- 最后按照函数实现对数据的处理
trim = xlsread('myExample.xlsx','MyData','','',@setMinMax)
(用空字符代替XRange和basic参数,此处用了两个空字符当占位符 placeholders)
2 返回数据的索引(按列计算)
- 函数要满足返回索引的需求
function [Data,indices] = setMinMax(Data)
minval = -3; maxval = 3;
indices = [];
for k = 1:Data.Count
v = Data.Value{k};
if v > maxval || v < minval
if v > maxval
Data.Value{k} = maxval;
else
Data.Value{k} = minval;
end
indices = [indices k];
end
end
- 调用指定函数
[trim,txt,raw,idx] = xlsread('myExample.xlsx',...'MyData','','',@setMinMax);
>>disp(idx)
>>7 9 11 15 19 20 23 24 30
以上就是关于xlsread函数的全部变体和用法
在help帮助的最后写明了xlsread函数的两个限制:
1 Limitationsxlsread reads only 7-bit ASCII characters(只能读取七位ASCII序列)
2 .xlsread does not support non-contiguous ranges(不支持非邻行的读取,也就是说只能读取相邻的行和列了~~~~(>_<)~~~~ )
.(选取特定列的方法,待定更新)
matlab怎么选取excel的特定列构成数组的更多相关文章
- C# EXCEL导入 混合列文字为空,找不到可安装的 ISAM的解决办法
C# EXCEL导入 混合列文字为空,找不到可安装的 ISAM的解决办法 使用C#导入 Excel数据到 DataTable,如果连接串中只写 Excel 8.0,则正常的字符列,数值列都没有问题,但 ...
- .NET 里操作Excel 出现有些列的数据取不到的问题
错误重现: ----------------------------------------------------------------------- 在导入Excel读取数据时,其中的一个字段保 ...
- LeetCode Excel Sheet Column Title (输出excel表的列名称)
题意:给一个数字n,输出excel表的列名称. 思路:其实观察可知道,是个26进制的标记而已.那就模拟一下,每次计算一位时就先左移1位,再进行计算. class Solution { public: ...
- jquery获取表格中特定列
jQuery().text() 如果有一个表格,我们要用jquery获取特定列,则需要修改列的索引值就好了,此句代码获取的是页面的第10列
- 将EXCEL中的列拼接成SQL insert插入语句
工作中经常需要将EXCEL文件中的数据导入到各种数据库,但是对于不熟悉数据库的人来说,如果直接使用命令执行导入,这无疑是一个难题,也是一个风险.这里我们直接在EXCEL文件中拼接成标准的SQL ins ...
- SharePoint 2013 搜索SharePoint 特定列和特定文档(自己定义搜索)
SharePoint 2013 搜索SharePoint 特定列和特定文档 1,操作步骤和图例,因语言和版本号的不同 我尽量使用抓图方式. 2. In Central Administration, ...
- 工作小应用:EXCEL查找两列重复数据
工作案例:excel存在A列.B列,需要找出B列没有A列的数据,具体做法如下(以office2007做案例): 1.点击 公式-定义名称 ,选中A列,填写名称“AAA”,选中B列,填写名称“BBB”: ...
- excel 如何为列添加指定内容(字符串)
excel 如何为列添加指定内容(字符串) CreateTime--2018年5月26日17:52:32 Author:Marydon 1.情景展示 D列的值需要获取B列的值并且在后面统一加上12 ...
- 用NPOI操作EXCEL-锁定列CreateFreezePane()
public void ExportPermissionRoleData(string search, int roleStatus) { var workbook = new HSSFWorkboo ...
随机推荐
- 解决 Node.js 错误 Error:listen EADDRINUSE
第一次尝试 node.js 中的 express 框架,写了第一个 js 文件之后,在 WebStorm 运行,到游览器刷新,成功运行. 又创建一个 js 文件,写的是静态路由的访问,结果出现了 Er ...
- [HDU6321]Dynamic Graph Matching(DP)
题意:给定一个n个点的无向图,开始没有边,然后m个操作,每次加边或者删边,每次操作后输出正好k个边的匹配数k=1,2,3,...n/2,n<=10,m<=30000 可以发现,n<= ...
- Node.js的Formidable模块的使用,方便快捷
服务用的是express ,如果不是很老的express框架,都有自带formidable 如果没有就下载一个 npm i formidable var formidable = require( ...
- BZOJ1001_狼抓兔子_KEY
题目传送门 由题意得是最小割问题,又由最大流最小割定理可得只需要求无向图的最大流即可. 建双向边,跑Dinic,EK会超时. 注意在DFS时要加"if(!res)dist[now]=0;&q ...
- TensorFlow:在PyCharm中配置TensorFlow
在本地配置好TensorFlow后,如何在PyCharm中配置TensorFlow呢? 只需将当前的Python编译环境配置为TensFlow安装路径中的Pyhton环境,具体操作如下: 1. 打开‘ ...
- Android 9 Pie震撼来袭 同步登陆WeTest
WeTest 导读 2018年8月7日,Google对外发布最新 Android 9.0 正式版系统,并宣布系统版本Android P 被正式命名为代号“Pie”,最新系统已经正式推送包括谷歌Pixe ...
- MySQL日期、字符串、时间戳互转
平时比较常用的时间.字符串.时间戳之间的互相转换,虽然常用但是几乎每次使用时候都喜欢去搜索一下用法:本文将作为一个笔记,整理一下三者之间的 转换(即:date转字符串.date转时间戳.字符串转dat ...
- VIN码识别:让VIN码采集so easy!
近几年汽车后市场呈喷井式发展,在过去的半年,汽车后市场规模已高达万亿级,产业前景广阔,与此同时行业运营也受信息区域化.数据不统一的制约,让企业面临着效率低下.规模化运行困难的痛点. 在汽车配件市场中, ...
- debian8+lnmp1.2一键安装+WordPress3.9
下载并安装LNMP一键安装包 wget -c http://soft.vpser.net/lnmp/lnmp1.2-full.tar.gz && tar zxf lnmp1.2-ful ...
- Visual Studio Code 工具使用教程
软件下载这里就不用讲了,安装完之后: 1.切换中文: 选择扩展 搜索“Language”,在下列选项选择 Chinese (Simplified) Language Pack for Visual S ...