例如:

要将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:

  1. 在工作表中执行一个函数 然后返回数值型数据
  •       在命令行中输入以下命令 产生一个随机的正态分布矩阵(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的特定列构成数组的更多相关文章

  1. C# EXCEL导入 混合列文字为空,找不到可安装的 ISAM的解决办法

    C# EXCEL导入 混合列文字为空,找不到可安装的 ISAM的解决办法 使用C#导入 Excel数据到 DataTable,如果连接串中只写 Excel 8.0,则正常的字符列,数值列都没有问题,但 ...

  2. .NET 里操作Excel 出现有些列的数据取不到的问题

    错误重现: ----------------------------------------------------------------------- 在导入Excel读取数据时,其中的一个字段保 ...

  3. LeetCode Excel Sheet Column Title (输出excel表的列名称)

    题意:给一个数字n,输出excel表的列名称. 思路:其实观察可知道,是个26进制的标记而已.那就模拟一下,每次计算一位时就先左移1位,再进行计算. class Solution { public: ...

  4. jquery获取表格中特定列

    jQuery().text() 如果有一个表格,我们要用jquery获取特定列,则需要修改列的索引值就好了,此句代码获取的是页面的第10列

  5. 将EXCEL中的列拼接成SQL insert插入语句

    工作中经常需要将EXCEL文件中的数据导入到各种数据库,但是对于不熟悉数据库的人来说,如果直接使用命令执行导入,这无疑是一个难题,也是一个风险.这里我们直接在EXCEL文件中拼接成标准的SQL ins ...

  6. SharePoint 2013 搜索SharePoint 特定列和特定文档(自己定义搜索)

    SharePoint 2013 搜索SharePoint 特定列和特定文档 1,操作步骤和图例,因语言和版本号的不同 我尽量使用抓图方式. 2.  In Central Administration, ...

  7. 工作小应用:EXCEL查找两列重复数据

    工作案例:excel存在A列.B列,需要找出B列没有A列的数据,具体做法如下(以office2007做案例): 1.点击 公式-定义名称 ,选中A列,填写名称“AAA”,选中B列,填写名称“BBB”: ...

  8. excel 如何为列添加指定内容(字符串)

      excel 如何为列添加指定内容(字符串) CreateTime--2018年5月26日17:52:32 Author:Marydon 1.情景展示 D列的值需要获取B列的值并且在后面统一加上12 ...

  9. 用NPOI操作EXCEL-锁定列CreateFreezePane()

    public void ExportPermissionRoleData(string search, int roleStatus) { var workbook = new HSSFWorkboo ...

随机推荐

  1. win10每次重新启动,eclipse不能打开,要重新配jdk环境的解决办法

    在后面加上反斜杠就好,也不知道是什么原因,知道的同学希望可以在下面的评论告诉我.

  2. [NOIP2017]列队(树状数组)

    定义第i行为所有的点(i,j),0<j<m 可以发现,每一行是相对独立的,每一次操作只会影响到当前行和最后一列 考虑每一行和最后一列各开一个树状数组,但这样显然会爆空间 实际上,对于没有离 ...

  3. vuetify.js框架 下拉框数据改变DOM原数据未清除

    今天遇到一个奇怪的bug 需求很简单,就是将“引擎能力”下拉框选中的值作为筛选条件传入到“样本类型”下拉框中,默认“样本类型”下拉框显示所有样本类型 看图: 如图所示,功能很简单. 其实还是对vuet ...

  4. sas简单使用

    1 数据存取: 逻辑库: libname  自己起的名字 ‘文件所在的路径’,若无这步数据则存在默认的work中. 另一个方法在sas里自己建立一个逻辑库,但是关闭后就消失了. 新建数据:data  ...

  5. leetcode笔记--7 Find the Difference

    question: Given two strings s and t which consist of only lowercase letters. String t is generated b ...

  6. 在ubuntu trusty下安装python的rasterio库

    就这些吧.. apt-get update -y apt-get install -y software-properties-common add-apt-repository ppa:ubuntu ...

  7. 解决美图看看不出现在“Open with”的子菜单中的问题

    最近由于特殊需求,要使用美图看看,Win10系统,美图看看工作倒也正常,但出现一个比较郁闷的情况,就是只能在“Open with”的最下面一个子菜单中选择“Choose another app”,然后 ...

  8. Mate20兼容性如何?WeTest带你抢先测!

    自从九月份 iPhone XS 系列发布后,WeTest团队迅速入库了iPhone XS和iPhone XR设备,十月份国内巨头华为也重磅推出了一款“Mate 20”设备,让下半年的国内手机市场又热闹 ...

  9. 汽车VIN码识别/汽车车架号OCR识别,移动端VIN码识别,OCR扫描工具

    本文推荐了一项汽车VIN码自动识别技术,用户通过手机“扫一扫”的简单操作,就可以快速识别VIN码,查询到车辆的详细信息,为汽修汽配.二手车交易.车辆监管.查勘理赔提高工作效率. VIN是英文Vehic ...

  10. Qt-第一个QML程序-4-自定义按钮类,动画,状态

    上篇中,我们写到了自己定义了一个按钮,但是呢,按照这样的写法,要写一个程序出来,那要累死了,所以,qml给我的感觉就是各种随便调用,所以了,可以自己写一个自己Button的qml,这样在以后用到了,就 ...