for循环中的MATLAB和单元阵列处理

aXo*_*Xon 5 arrays matlab for-loop cell

我是MATLAB的新手,想从我从数据库中获取的单元格数据中提取数据:

sensors = 

[ 1]    [23]    [1]    [  0]    [0.1000]            [1x29 char]
[ 2]    [23]    [1]    [120]    [0.1000]            [1x43 char]
[ 3]    [23]    [1]    [120]    [0.1000]            [1x42 char]
[ 4]    [23]    [1]    [ 15]    [0.1000]    'Air Temp Grey Box'
[ 5]    [23]    [1]    [120]    [0.1000]            [1x34 char]
[ 6]    [23]    [1]    [120]    [0.1000]            [1x33 char]
[ 7]    [23]    [1]    [120]    [0.1000]    'Pool Water Temp'  
[ 8]    [23]    [2]    [  0]    [0.1000]            [1x28 char]
[ 9]    [23]    [1]    [ 30]    [0.1000]            [1x22 char]
[10]    [23]    [1]    [ 30]    [0.1000]            [1x22 char]
[11]    [23]    [1]    [ 30]    [0.1000]            [1x21 char]
[12]    [23]    [1]    [ 15]    [0.1000]            [1x20 char]
[13]    [23]    [1]    [ 15]    [0.1000]            [1x23 char]
[14]    [23]    [1]    [ 30]    [0.1000]            [1x22 char]
[15]    [23]    [1]    [ 15]    [0.1000]    'Ground Air '      
[16]    [23]    [1]    [  5]    [0.1000]    'Boiler Cold Water'
[17]    [23]    [1]    [  5]    [0.1000]    'Boiler Hot Water' 
[18]    [23]    [1]    [  5]    [0.1000]    'Boiler CH Flow'   
[19]    [23]    [1]    [  5]    [0.1000]    'Boiler CH Return' 
Run Code Online (Sandbox Code Playgroud)

现在我想抓住第一列,即数字1到19以及最后一列中的相应名称,并在for循环中使用它们,例如:

for ID=xxxx
    str = num2str(ID);
    SQLcommand = strcat('SELECT FROM data where ID=',str);
    answer = database.exec(SQLcommand);
    ......
end
Run Code Online (Sandbox Code Playgroud)

我已经尝试了几次不同的尝试,但从未成功获得其中一个元素.

感谢帮助:),提前谢谢.轴突

Mar*_*arc 6

虽然上面的圣人的答案是有效的,但它并不是真正适当的,也不是有效地使用Matlab的单元阵列.您可以通过使用适当的单元格数组内容索引来消除许多无关的函数调用.你可以用两种方式处理单元格数组的任何元素 - ()或者{}. ()得到细胞,仍然是一个细胞. {}然而,拉出单元格的内容,以它的基本类型.

所以sensors(1, end)是1x1单元阵列,但是sensors{1, end}1x29字符串.

对于你的问题:

numRows = size(sensors, 1);
for rowIdx = 1:numRows;
    sensorName = sensors{rowIdx, end};
    sql = ['select * from data where ID = ' num2str(sensors{rowIdx, 1})];
    ...
end
Run Code Online (Sandbox Code Playgroud)

num2str()如果您将传感器ID作为char而不是数字获取,也可以取消调用 - 即,如果您的原始数据库获取已填充的传感器执行了转换.

另外,如果你没有从数据库中进一步查询,你可以对整个事情进行矢量化,但是我担心我离开了我的Matlab机器,所以我无法在我的头顶上构建那个.