24小时热门版块排行榜    

CyRhmU.jpeg
查看: 3543  |  回复: 7

windy1011

银虫 (初入文坛)

[求助] 如何根据矩阵中特定元素提取元素所在行的全部信息已有1人参与

[40  10  10   0  75.8291  -9.1164  -13.7194
50        20  10  80  70.0268  -14.7433  -19.982
60        10  30  0  64.3484  -19.7989  -25.4583
70        10  10  100  61.7309  -23.0001  -28.8289
40        30  10  10  52.8051  -27.8773  -40.3002
90        10  50  0  54.7763  -31.5686  -38.2046
100        10  10  20  52.1687  -36.6261  -42.627
10        60  50  0  83.4774  4.4897  -4.3057
20        20  10  0  79.7278  2.0888  -5.0903
30        20  10  40  76.1861  -0.7425  -9.0672
40        60  0  10  72.2374  -4.393  -14.2564
50        20  10  0  67.2916  -9.6956  -20.2217]

我有一个矩阵  6000行  7列  ,其中,前四列是0 5 10 20 30 40 50 60 70 80 90 100 这几个数字随机排列起来的,截取了其中一部分数据,如上表。
现在我想按照特定的条件提取正行。条件是 第一列数字为40,并且第二列数字可以是0 5 10 20 30 40 50 60 70 80 90 100当中的任何一个,并且第三列数字可以是0 5 10 20 30 40 50 60 70 80 90 100当中的任何一个,并且第四列数字为10.筛选出所有满足这四个条件的整行元素,并且把这些元素所在的整行提取出来,组成新的矩阵,请问这个怎么解决呢?谢谢!


就拿我给出的这部分数据来说 最后的提取结果是
[40        30        10        10        52.8051        -27.8773        -40.3002
40        60        0        10        72.2374        -4.393        -14.2564]

这种效果的
回复此楼
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

windy1011

银虫 (初入文坛)

忘了说 是matlab
2楼2017-04-09 18:07:29
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

pdl9527

专家顾问 (小有名气)

【答案】应助回帖

感谢参与,应助指数 +1
CODE:
function question_40
clear;clc
R=[0 5 10 20 30 40 50 60 70 80 90 100];
MAT=[40  10  10   0  75.8291  -9.1164  -13.7194
50        20  10  80  70.0268  -14.7433  -19.982
60        10  30  0  64.3484  -19.7989  -25.4583
70        10  10  100  61.7309  -23.0001  -28.8289
40        30  10  10  52.8051  -27.8773  -40.3002
90        10  50  0  54.7763  -31.5686  -38.2046
100        10  10  20  52.1687  -36.6261  -42.627
10        60  50  0  83.4774  4.4897  -4.3057
20        20  10  0  79.7278  2.0888  -5.0903
30        20  10  40  76.1861  -0.7425  -9.0672
40        60  0  10  72.2374  -4.393  -14.2564
50        20  10  0  67.2916  -9.6956  -20.2217];
j=1;
for i=1:size(MAT,1)
    if MAT(i,1)==40 && any(R==MAT(i,2)) && any(R==MAT(i,3)) && MAT(i,4)==10
        res(j,:)=MAT(i,:);
        j=j+1;
    end
end
disp(res)

3楼2017-04-10 18:37:12
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

windy1011

银虫 (初入文坛)

引用回帖:
3楼: Originally posted by pdl9527 at 2017-04-10 18:37:12
function question_40
clear;clc
R=;
MAT=;
j=1;
for i=1:size(MAT,1)
    if MAT(i,1)==40 && any(R==MAT(i,2)) && any(R==MAT(i,3)) && MAT(i,4)==10
        res(j,=MAT(i,: ...

厉害了 !输出结果是对的。 但是输出结果需要的是矩阵, 不是字符串。这个例子当中 输出结果变为是2行7列的矩阵,再麻烦您修改一下啦!!谢谢您!!
4楼2017-04-11 08:55:53
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

windy1011

银虫 (初入文坛)

引用回帖:
3楼: Originally posted by pdl9527 at 2017-04-10 18:37:12
function question_40
clear;clc
R=;
MAT=;
j=1;
for i=1:size(MAT,1)
    if MAT(i,1)==40 && any(R==MAT(i,2)) && any(R==MAT(i,3)) && MAT(i,4)==10
        res(j,=MAT(i,: ...

厉害了 !输出结果是对的。 但是输出结果需要的是矩阵, 不是字符串。就是说,通过限定的条件把符合条件的一整行筛选出来 ,这些行组成了一个新的矩阵。在这个例子当中 输出结果变为是2行7列的矩阵,再麻烦您修改一下啦!!谢谢您!!
5楼2017-04-11 09:00:51
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

pdl9527

专家顾问 (小有名气)

【答案】应助回帖

结果保存在res里面,你可以在结尾加上size(res),得到的结果是2,7说明res就是2行7列的矩阵,根本不是你说的字符串啊...
6楼2017-04-11 17:32:50
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

windy1011

银虫 (初入文坛)

引用回帖:
6楼: Originally posted by pdl9527 at 2017-04-11 17:32:50
结果保存在res里面,你可以在结尾加上size(res),得到的结果是2,7说明res就是2行7列的矩阵,根本不是你说的字符串啊...

不好意思啊 matlab我的基础特别不好,其实我就是想把输出结果保存城一个.mat文件 。我把您的这两行输出结果复制粘贴到新建的.mat当中,提示是“无法将剪贴板中的数据粘贴到数组中。请注意,matla数值数组不能包含字符串。如果您要尝试将字符串粘贴到数组中,请考虑改用元胞数组”。

还是要麻烦您一下了
7楼2017-04-12 08:28:02
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

pdl9527

专家顾问 (小有名气)

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★ ★
windy1011: 金币+10, ★★★★★最佳答案, 谢谢你,筛选结果可以后 但是我就是导不出来,辛苦你了! 2017-04-14 08:44:45
引用回帖:
7楼: Originally posted by windy1011 at 2017-04-12 08:28:02
不好意思啊 matlab我的基础特别不好,其实我就是想把输出结果保存城一个.mat文件 。我把您的这两行输出结果复制粘贴到新建的.mat当中,提示是“无法将剪贴板中的数据粘贴到数组中。请注意,matla数值数组不能包含字 ...

在结尾加上下列代码就可以了。
CODE:
save result.mat res

8楼2017-04-12 17:10:36
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 windy1011 的主题更新
信息提示
请填处理意见