Find a value with cell array.
2 次查看(过去 30 天)
显示 更早的评论
I'm using Matlab 7.14. I have a cell array with one column of numbers and one column of characters. i.e.
6 'text6'
5 'text5'
7 'text7'
3 'text3'
I want find a particular value (let's say 7) in the first column, and then use the reference to get at the text value in the same row (much like VLOOKUP in Excel). If this were just a numeric array I would use a = find(arrayname(:,1)==7) to get the row number (a would = 3) and then I could just get the text value via b = arrayname(a,2);
My question is how to find this reference/row number in my cell array? I've tried using a=cellfun(find(chart_list{:,1}==7)) but it returns the error 'Too many input arguments'. Can you use 'find' with cell arrays?
Any ideas how to find a value in an array?
Thanks Rob
0 个评论
采纳的回答
Jos (10584)
2015-2-24
No need for cell2mat, simple concatenation would do:
val = [A{:,1}]
tf = val == 7
out = A(tf,2)
which you can do as a one-liner as well, of course:
A([A{:,1}]==7,2)
更多回答(1 个)
Shoaibur Rahman
2015-2-24
编辑:Shoaibur Rahman
2015-2-24
A = your cell...
out = A(cell2mat(A(:,1))==7,2)
另请参阅
类别
在 Help Center 和 File Exchange 中查找有关 Cell Arrays 的更多信息
产品
Community Treasure Hunt
Find the treasures in MATLAB Central and discover how the community can help you!
Start Hunting!